我想像这样处理一些XML:
<rows>
<row>
<country>AT</country>
<some>element</some>
</row>
<row>
<country>CZ</country>
<some>element</some>
</row>
<row>
<country>BG</country>
<some>element</some>
</row>
<row>
<country>CZ</country>
<some>element</some>
</row>
</rows>
我必须以这种方式将行重新组合到目标XML:首先必须是具有国家/地区&#39; CZ&#39;的行,然后可以是与其他国家/地区的行。
我可以选择国家&#39; CZ&#39;这样:
<xsl:key name="countries" match="row" use="country">
<xsl:for-each select="key('countries', 'CZ')">
<!-- do some transformation -->
</xsl:for-each>
但我不知道如何与其他国家一起捡行?我可以使用像:
这样的想法吗?<xsl:for-each select="key('countries', !'CZ')">
编辑:
预期输出为:
<rows>
<row>
<country>CZ</country>
<transformed>element</transformed>
</row>
<row>
<country>CZ</country>
<transformed>element</transformed>
</row>
<row>
<country>AT</country>
<transformed>element</transformed>
</row>
<row>
<country>BG</country>
<transformed>element</transformed>
</row>
</rows>
其他行的顺序(除了&#39; CZ&#39;)不是强制性的。
我使用的是XSLT 1.0,但我也可以使用XSLT 2.0。
答案 0 :(得分:1)
即使没有xsl:key
。
选择CZ行:
<xsl:apply-templates select="//row[country='CZ']"/>
选择其他行:
<xsl:apply-templates select="//row[country!='CZ']"/>
您也可以在xsl:for-each
中使用相同的表达式。
答案 1 :(得分:1)
恕我直言,改变节点顺序最直接的方法是排序 - 例如:
XSLT 1.0
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="xml" version="1.0" encoding="UTF-8" indent="yes"/>
<xsl:strip-space elements="*"/>
<!-- identity transform -->
<xsl:template match="@*|node()">
<xsl:copy>
<xsl:apply-templates select="@*|node()"/>
</xsl:copy>
</xsl:template>
<xsl:template match="/rows">
<xsl:copy>
<xsl:apply-templates select="row">
<xsl:sort select="number(country='CZ')" data-type="number" order="descending"/>
</xsl:apply-templates>
</xsl:copy>
</xsl:template>
<xsl:template match="some">
<transformed>
<xsl:apply-templates/>
</transformed>
</xsl:template>
</xsl:stylesheet>