gpt4 book ai didi

xslt - 如何在 XSLT 中对值进行分组和求和

转载 作者:行者123 更新时间:2023-12-02 11:45:02 25 4
gpt4 key购买 nike

对于每个“agency”节点,我需要找到具有相同 key1、key2、key3 值的“stmt”元素,并仅输出一个“stmt”节点,其中“comm”和“prem”值相加在一起。对于该“agency”中与基于 key1、key2 和 key3 的任何其他“stmt”元素不匹配的任何“stmt”元素,我需要按原样输出它们。因此,转换后,第一个“agency”节点将只有两个“stmt”节点(一个求和),第二个“agency”节点将按原样传递,因为键不匹配。 XSLT 1.0 或 2.0 解决方案都可以...尽管我的样式表当前是 1.0。请注意,代理节点可以有任意数量的“stmt”元素,这些元素具有需要分组和求和的匹配键,也可以有任意数量的不需要分组和求和的元素。

<statement>
<agency>
<stmt>
<key1>1234</key1>
<key2>ABC</key2>
<key3>15.000</key3>
<comm>75.00</comm>
<prem>100.00</prem>
</stmt>
<stmt>
<key1>1234</key1>
<key2>ABC</key2>
<key3>15.000</key3>
<comm>25.00</comm>
<prem>200.00</prem>
</stmt>
<stmt>
<key1>1234</key1>
<key2>ABC</key2>
<key3>17.50</key3>
<comm>25.00</comm>
<prem>100.00</prem>
</stmt>
</agency>
<agency>
<stmt>
<key1>5678</key1>
<key2>DEF</key2>
<key3>15.000</key3>
<comm>10.00</comm>
<prem>20.00</prem>
</stmt>
<stmt>
<key1>5678</key1>
<key2>DEF</key2>
<key3>17.000</key3>
<comm>15.00</comm>
<prem>12.00</prem>
</stmt>
</agency>

最佳答案

以及 XSLT 2.0 解决方案:

<xsl:stylesheet version="2.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:xs="http://www.w3.org/2001/XMLSchema"
exclude-result-prefixes="xs"
>
<xsl:output omit-xml-declaration="yes" indent="yes"/>

<xsl:template match="node()|@*">
<xsl:copy>
<xsl:apply-templates select="node()|@*"/>
</xsl:copy>
</xsl:template>

<xsl:template match="agency">
<agency>
<xsl:for-each-group select="stmt" group-by=
"concat(key1, '+', key2, '+', key3)">

<stmt>
<xsl:copy-of select=
"current-group()[1]/*[starts-with(name(),'key')]"/>

<comm>
<xsl:value-of select="sum(current-group()/comm)"/>
</comm>
<prem>
<xsl:value-of select="sum(current-group()/prem)"/>
</prem>
</stmt>
</xsl:for-each-group>
</agency>
</xsl:template>
</xsl:stylesheet>

关于xslt - 如何在 XSLT 中对值进行分组和求和,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2768712/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com