这是我的第一个stackoverflow问题:
我有一个像这样的XML文件:
<ROOT>
<COLUMN ID="AA1">
<CAPTION>Some Text 1</CAPTION>
</COLUMN>
<COLUMN ID="AA1">
<CAPTION>Some Text 2</CAPTION>
</COLUMN>
<COLUMN ID="AA1">
<CAPTION>Some Text 3</CAPTION>
</COLUMN>
<COLUMN ID="AA2">
<CAPTION>Some Text 4</CAPTION>
</COLUMN>
<COLUMN ID="AA2">
<CAPTION>Some Text 5</CAPTION>
</COLUMN>
</ROOT>
我希望将其转换为:
结果应该是所有列ID都已分组,并且每个组中的CAPTION都已合并
我不知道ID值,我不关心它们。只是按他们分组。
这应该是结果,在这种情况下是两个字符串:
“有些文字1有些文字2有些文字3”
“有些文字4有些文字5”
所有这些,使用Xpath2
我真的不确定它是否只能用xpath exssion完成,但我希望......
有人有想法吗?
答案 0 :(得分:0)
使用
for $id in distinct-values(/ROOT/COLUMN/@ID)
return string-join(/ROOT/COLUMN[@ID = $id]/CAPTION, ' ')
答案 1 :(得分:0)
要进行分组,请查看this answer。 您可以通过使用像这样的XSLT来实现这一点:
<xsl:stylesheet version="2.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="xml" indent="yes" encoding="utf-8" omit-xml-declaration="yes"/>
<xsl:key name="id" match="COLUMN" use="@ID" />
<xsl:template match="ROOT">
<OUTPUT>
<xsl:apply-templates select="COLUMN[generate-id(.)=generate-id(key('id',@ID)[1])]" />
</OUTPUT>
</xsl:template>
<xsl:template match="COLUMN">
<xsl:element name="COLUMN">
<xsl:attribute name="ID">
<xsl:value-of select="@ID" />
</xsl:attribute>
<xsl:for-each select="key('id', @ID)">
<xsl:value-of select="CAPTION" />
<xsl:text> </xsl:text>
</xsl:for-each>
</xsl:element>
</xsl:template>
</xsl:stylesheet>
它将输出如下:
<OUTPUT>
<COLUMN ID="AA1">Some Text 1 Some Text 2 Some Text 3 </COLUMN>
<COLUMN ID="AA2">Some Text 4 Some Text 5</COLUMN>
</OUTPUT>