我必须循环通过Main/MainLines/MainLine,并得到和(数量) for-each - Item/ItemNo.The输出应该只有一个MainLine元素,我正在做的每一个ItemNo.The方式,我得到重复。
输入
<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>发布于 2016-12-07 11:40:22
这是一个门窗群问题。您可以只通过迭代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>https://stackoverflow.com/questions/41012374
复制相似问题