Я пытаюсь перебрать документ xml, используя xsl: foreach, но мне нужно, чтобы select = "" был динамическим, поэтому я использую переменную в качестве источника. Вот что я попробовал:
...
<xsl:template name="SetDataPath">
<xsl:param name="Type" />
<xsl:variable name="Path_1">/Rating/Path1/*</xsl:variable>
<xsl:variable name="Path_2">/Rating/Path2/*</xsl:variable>
<xsl:if test="$Type='1'">
<xsl:value-of select="$Path_1"/>
</xsl:if>
<xsl:if test="$Type='2'">
<xsl:value-of select="$Path_2"/>
</xsl:if>
<xsl:template>
...
<!-- Set Data Path according to Type -->
<xsl:variable name="DataPath">
<xsl:call-template name="SetDataPath">
<xsl:with-param name="Type" select="/Rating/Type" />
</xsl:call-template>
</xsl:variable>
...
<xsl:for-each select="$DataPath">
...
В foreach возникла ошибка: «XslTransformException - чтобы использовать фрагмент результирующего дерева в выражении пути, сначала преобразуйте его в набор узлов, используя функцию msxsl: node-set ().»
Когда я использую функцию msxsl: node-set (), мои результаты остаются пустыми.
Я знаю, что я устанавливаю $ DataPath в строку, но разве функция node-set () не должна создавать из нее набор узлов? Я что-то пропустил? Когда я не использую переменную:
<xsl:for-each select="/Rating/Path1/*">
Я получаю правильные результаты.
Вот файл данных XML, который я использую:
<Rating>
<Type>1</Type>
<Path1>
<sarah>
<dob>1-3-86</dob>
<user>Sarah</user>
</sarah>
<joe>
<dob>11-12-85</dob>
<user>Joe</user>
</joe>
</Path1>
<Path2>
<jeff>
<dob>11-3-84</dob>
<user>Jeff</user>
</jeff>
<shawn>
<dob>3-5-81</dob>
<user>Shawn</user>
</shawn>
</Path2>
</Rating>
У меня простой вопрос, как вы запускаете foreach по двум разным путям?