我正在尝试从 XML 中提取唯一值以及它们出现的次数。
我一直在关注 Xslt distinct select / Group by中给出的答案,但我的架构有点不同。
我的 XML 看起来类似于:
<A>
<B>
<C>
<D>APPLE</D>
</C>
</B>
<B>
<C>
<D>BANANA</D>
</C>
</B>
<B>
<C>
<D>APPLE</D>
</C>
</B>
</A>
根据上一个答案中的代码,我有:
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="text" />
<xsl:key
name="C-by-DValue"
match="B/C/D"
use="text()"
/>
<xsl:template match="A">
<xsl:for-each select="
B/C/D[
count(
. | key('C-by-DValue', B/C/D/text())[1]
) = 1
]
">
<xsl:value-of select="text()"/>
<xsl:value-of select="' - '"/>
<!-- simple: the item count is the node count of the key -->
<xsl:value-of select="
count(
key('C-by-DValue', text())
)
"/>
<xsl:value-of select="' '"/>
</xsl:for-each>
</xsl:template>
</xsl:stylesheet>
但这会返回:
APPLE - 2
BANANA - 1
APPLE - 2
因此,for-each-select 不仅匹配每个 text() 值的第一个实例。请有人指出我正确的方向。