0

我有一个这样的xml:

<root>
<row>
    <col name="col1">&lt;root&gt;&lt;row&gt;&lt;col name=&quot;COL_NAME_1&quot;&gt;col_value_1&lt;/col&gt;;&lt;/row&gt;&lt;/root&gt;</col>
    <col name="col2">&lt;root&gt;&lt;row&gt;&lt;col name=&quot;COL_NAME_2&quot;&gt;col_value_2&lt;/col&gt;;&lt;/row&gt;&lt;/root&gt;</col>
</row></root>

我需要从 col1 中获取转义集合并遍历其行。我正在使用 exsl:node-set 函数。这是我的简化 xsl:

<xsl:template match="/">
<xsl:variable name="collection" select="exsl:node-set(./root/row/col[@name='col1'])" disable-output-escaping="yes" />
<xsl:for-each select="($collection)/root/row">
    <!-- ... -->
</xsl:for-each></xsl:template>

我可以使用 xsl:value-of 函数从变量 $collection 中正确读取值,但我无法像没有行一样对其进行迭代。任何想法我做错了什么?

4

2 回答 2

1

如果此 XML 的作者希望您在 col 元素中看到诸如 root 和 row 之类的元素,他们就不会转义尖括号。因为它们被转义了,所以这里没有结构,只有文本。从文本中获取结构的操作称为解析。XSLT 3.0 有一个函数 parse-xml() 来解析文本并创建树结构;早期版本没有,尽管您的供应商可能会提供扩展,或者您可以自己编写。

于 2015-03-31T21:55:08.340 回答
0

node-set()函数不解析。您的$collection变量是一个节点集,由一个带有一个col子节点的临时文档节点组成。

Saxon 有一个名为的扩展函数parse(),它可以满足您的需求,其他一些 XSLT 处理器也是如此。我也看到了一些用纯 XSLT 编写代码的尝试,但不知道是否有一个好的实现。

于 2015-03-31T14:53:36.050 回答