我必须循环循环 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>