我有这样的XML数据:
<data ItemCount="5">
<zrow GroupName="Manager"User="User1" />
<zrow GroupName="Developer"User="User2" />
<zrow GroupName="Manager"User="User3" />
<zrow GroupName="CEO"User="User4" />
<zrow GroupName="CEO"User="User5" />
</data>
我想要这样的输出:
Manager
User1
User3
Developer
User2
CEO
User4
User5
我的XSLT应该是什么?我想创建一个XSLT,它应该将我的数据转换为上述格式。你能帮我创一个吗?
答案 0 :(得分:1)
XSLT 2.0解决方案:
<xsl:stylesheet version="2.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="text"/>
<xsl:template match="data">
<xsl:for-each-group select="zrow" group-by="@GroupName">
<xsl:value-of select="current-grouping-key()" />
<xsl:text>
</xsl:text>
<xsl:value-of select="current-group()/@User" separator="
"/>
<xsl:text>
</xsl:text>
</xsl:for-each-group>
</xsl:template>
</xsl:stylesheet>
XSLT 1.0解决方案依赖于Muenchian方法:
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="text"/>
<xsl:strip-space elements="*"/>
<xsl:key name="byGroupName" match="zrow" use="@GroupName"/>
<xsl:template
match="zrow[generate-id()=
generate-id(key('byGroupName', @GroupName)[1])]">
<xsl:value-of select="@GroupName"/>
<xsl:text>
</xsl:text>
<xsl:apply-templates select="key('byGroupName', @GroupName)" mode="out"/>
</xsl:template>
<xsl:template match="zrow" mode="out">
<xsl:value-of select="@User"/>
<xsl:text>
</xsl:text>
</xsl:template>
<xsl:template match="zrow"/>
</xsl:stylesheet>