XSLT:循环并获得唯一的属性值



我必须循环循环 Main/MainLines/MainLine并获取sum(数量) for-each - Item/ItemNo。每个 ItemNo的输出应只有一个 MainLine元素。我正在重复我的方式。<<<<<<<<<<<<<</p>

输入

<Main Company="ABC" MainNo="213211" >
  <MainLines>
    <MainLine Quantity="2"  Node="9999">
      <Item ItemNo="123123" Class="NEW"/>
    </MainLine>
    <MainLine Quantity="1"  Node="9999">
      <Item ItemNo="123123" Class="NEW"/>
    </MainLine>
    <MainLine Quantity="3"  Node="9999">
      <Item ItemNo="123123" Class="NEW"/>
    </MainLine>
    <MainLine Quantity="2"  Node="9999">
      <Item ItemNo="22222" Class="NEW"/>
    </MainLine>
  </MainLines>
</Main>

输出

<Main Company="ABC" MainNo="213211" Reason="NewFile">
  <MainLines>
    <MainLine ExtnQuantity="6">
      <MainLine Quantity="2" Node="9999">
        <Item ItemNo="123123" Class="NEW" />
      </MainLine>
    </MainLine>
    <MainLine ExtnQuantity="6">
      <MainLine Quantity="1" Node="9999">
        <Item ItemNo="123123" Class="NEW" />
      </MainLine>
    </MainLine>
    <MainLine ExtnQuantity="6">
      <MainLine Quantity="3" Node="9999">
        <Item ItemNo="123123" Class="NEW" />
      </MainLine>
    </MainLine>
    <MainLine ExtnQuantity="2">
      <MainLine Quantity="2" Node="9999">
        <Item ItemNo="22222" Class="NEW" />
      </MainLine>
    </MainLine>
  </MainLines>
</Main>

xsl

<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
  <xsl:output method="xml" indent="yes"/>
  <xsl:template match="/">
  <Main>
    <xsl:copy-of select="Main/@*"/>
    <xsl:attribute name="Reason">
      <xsl:value-of select="'NewFile'"/>
    </xsl:attribute>
    <MainLines>
      <xsl:for-each select="Main/MainLines/MainLine">
        <MainLine>
          <xsl:variable name="ITEM_ID">
            <xsl:value-of select="Item/@ItemNo"/>
          </xsl:variable>
          <xsl:attribute name="ExtnQuantity">
            <xsl:value-of select="sum(../MainLine[Item/@ItemNo = $ITEM_ID]/@Quantity)"/>
          </xsl:attribute>
          <xsl:copy-of select="."/>
        </MainLine>
      </xsl:for-each>
    </MainLines>
  </Main>
  </xsl:template>
</xsl:stylesheet>

预期输出

<Main Company="ABC" MainNo="213211" Reason="NewFile">
  <MainLines>
    <MainLine ExtnQuantity="6">
      <MainLine Quantity="2" Node="9999">
        <Item ItemNo="123123" Class="NEW" />
      </MainLine>
    </MainLine>
    <MainLine ExtnQuantity="2">
      <MainLine Quantity="2" Node="9999">
        <Item ItemNo="22222" Class="NEW" />
      </MainLine>
    </MainLine>
  </MainLines>
</Main>

这是一个穆奇分组问题。您只能通过ItemNo的唯一值迭代来解决它。这是您的样式表的改编版:

请注意,我已经将<MainLines>元素移至其自己的模板中以减少嵌套。另外,您可以将属性直接添加到一个元素,您不需要<xsl:attribute>

<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
  <xsl:output method="xml" indent="yes" />
  <!-- Define key -->
  <xsl:key name="ItemNoKey" match="MainLine/Item" use="@ItemNo" />
  <xsl:template match="/Main">
    <Main Reason="NewFile">
      <xsl:copy-of select="@*"/>
      <xsl:apply-templates select="MainLines"/>
    </Main>
  </xsl:template>
  <xsl:template match="MainLines">
    <MainLines>
      <!-- For each first MainLine with a given ItemNo -->
      <xsl:for-each select="MainLine[count(Item | key('ItemNoKey', Item/@ItemNo)[1]) = 1]">
        <xsl:variable name="CurrentItemNo" select="Item/@ItemNo"/>
        <!-- Print MainLine with quantity sum -->
        <MainLine ExtnQuantity="{sum(../MainLine[Item/@ItemNo = $CurrentItemNo]/@Quantity)}">
          <!-- Copy the selected MainLine element -->
          <xsl:copy-of select="."/>
        </MainLine>
      </xsl:for-each>
    </MainLines>
  </xsl:template>
</xsl:stylesheet>

相关内容

  • 没有找到相关文章

最新更新