Xpath concat重复按不同属性分组的元素

时间:2014-02-05 12:50:26

标签: xml xpath concat

这是我的第一个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完成,但我希望......

有人有想法吗?

2 个答案:

答案 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>