1

こんにちは、いくつかの属性に基づいて値を 2 回グループ化し、入力する必要があります。

xmlの下にあり、UITVOERINGSNIVEAUとEnveloppeでグループ化が必要です

<rows>
  <row Enveloppe="ACOS" POST_NUM="1000" UITVOERINGSNIVEAU="BnComd" CSTAMNUMMER="1" /> 
  <row Enveloppe="ACOS" POST_NUM="5000" UITVOERINGSNIVEAU="BnComd" CSTAMNUMMER="2" /> 
  <row Enveloppe="DG" POST_NUM="1001" UITVOERINGSNIVEAU="BdeComd" CSTAMNUMMER="4" /> 
</rows>

以下のような結果が欲しいです。

<rows> 
      <row> 
        <cell image="folder.gif">BnComd</cell> 
        <row>
           <cell image="folder.gif">ACOS</cell> 
              <row> 
                 <cell>1000</cell> 
                 <cell>1</cell>
              </row>
              <row>
                 <cell>5000</cell> 
                 <cell>2</cell>
              <row>
        </row>  
     </row>
     <row> 
        <cell image="folder.gif">BdeComd</cell> 
          <row> 
            <cell image="folder.gif">DG</cell>
              <row> 
                 <cell>1001</cell> 
                 <cell>4</cell>
              </row>
        </row>
      </row> 
    </rows>

UITVOERINGSNIVEAU のみで group-by を実行するためにこれを見つけましたが、2 番目の group-by を統合する方法がわかりません。

<xsl:template match="/*">
  <rows>
    <xsl:for-each-group select="//rows/row" group-by="@UITVOERINGSNIVEAU">
      <row>
        <cell image="folder.gif"><xsl:value-of select="current-grouping-key()"/></cell>
        <xsl:apply-templates select="current-group()"/>
      </row>
    </xsl:for-each-group>
  </rows>
</xsl:template>

<xsl:template match="row">
  <row>
    <xsl:apply-templates select="@* except @UITVOERINGSNIVEAU"/>
  </row>
</xsl:template>

<xsl:template match="row/@*">
  <cell><xsl:value-of select="."/></cell>
</xsl:template>

誰かが私を助けてくれますか?

ありがとう

4

1 に答える 1