簡體   English   中英

從XSLT中的名稱/值對中刪除/添加重復值

[英]removing/adding duplicates values from name value pair in XSLT

我有下面的xml

   <pair>
            <name>ABC</name>
            <value>10</value>
    </pair>
    <pair>
            <name>ABC</name>
            <value>50</value>
    </pair>
    <pair>
            <name>XYZ</name>
            <value>30</value>
    </pair>

應該掩蓋成

<pair>
        <name>ABC</name>
        <value>60</value>
</pair>
<pair>
        <name>XYZ</name>
        <value>30</value>
</pair>

也就是說,名稱在名稱值對中相同。 帶有相同名稱的值應添加到輸出xml中。 有人可以幫忙嗎?

假設您可以使用XSLT 2.0和像Saxon 9這樣的XSLT 2.0處理器

<xsl:template match="/*">
  <xsl:copy>
    <xsl:for-each-group select="//pair" group-by="name">
      <xsl:copy>
        <xsl:copy-of select="name"/>
        <value><xsl:value-of select="sum(current-group()/value)"/></value>
      </xsl:copy>
    </xsl:for-each-group>
  </xsl:copy>
</xsl:template>

XML:

<parent>
    <pair>
        <name>ABC</name>
        <value>10</value>
    </pair>
    <pair>
        <name>ABC</name>
        <value>50</value>
    </pair>
    <pair>
        <name>XYZ</name>
        <value>30</value>
    </pair>
</parent>

XSLT:

<xsl:template match="/">
        <parent>
            <xsl:for-each select="//parent/pair[not(name=preceding::pair/name)]">
                <xsl:variable name="curName" select="name" />
                <pair>
                <name>
                <xsl:value-of select="name"/>
                </name>
                <value>
                <xsl:value-of select="sum(/parent/pair[name = $curName]/value)"/>
                </value>
                </pair>
            </xsl:for-each>
        </parent>
</xsl:template>

要么:

<xsl:key name="pair-by-name" match="parent/pair" use="name" />
<xsl:template match="/">
    <parent>
        <xsl:for-each select="parent/pair[count(. | key('pair-by-name', name)[1]) = 1]">
             <xsl:sort select="name" />
            <pair>
            <name>
            <xsl:value-of select="name"/>
            </name>
            <value>
            <xsl:value-of select="sum(key('pair-by-name', name)/value)"/>
            </value>
            </pair>
        </xsl:for-each>
    </parent>
</xsl:template>

上面的代碼應該工作。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM