输入XML
<root>
<data>
<reportable>
<row index="1">
<tn>name1</tn>
</row>
<row index="2">
<tn>name3</tn>
</row>
<row index="3">
<tn>currency</tn>
<value>$</value>
</row>
<row index="4">
<tn>name2</tn>
</row>
</reportable>
<name1 type="table" cols="2" row="1">
<row index="1">
<fname>AAK</fname>
<lname>BB</lname>
</row>
</name1>
<name2 type="table" cols="2" row="1">
<row index="1">
<fname>KA</fname>
<lname>A</lname>
</row>
</name2>
<name3 type="table" cols="2" row="1">
<row index="1">
<fname>Arun</fname>
<lname>Kumar</lname>
</row>
</name3>
</data>
</root>
示例XSLT
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:msxsl="urn:schemas-
microsoft-com:xslt" exclude-result-prefixes="msxsl">
<xsl:output method="xml" indent="yes"/>
<xsl:strip-space elements="*"/>
<xsl:template match="/root/data/reporttable">
<xsl:for-each select="row" >
<xsl:choose>
<xsl:when test="contains(tn,'name')">
<xsl:call-template name='temp2'>
<xsl:with-param name='pathValue' select="concat('../',tn)"/>
</xsl:call-template>
</xsl:when>
<xsl:when test="tn='currency'">
<curr>
<xsl:value-of select="value"/>
</curr>
</xsl:when>
</xsl:choose>
</xsl:for-each>
</xsl:template>
<xsl:template name="temp2">
<xsl:param name="pathValue"/>
<valueofFname>
<xsl:value-of select="$pathValue/row/fname"/>
</valueofFname>
</xsl:template>
</xsl:stylesheet>
预期输出XML
<valueofFname>AAK</valueofFname>
<valueofFname>Arun</valueofFname>
<curr>$</curr>
<valueofFname>KA</valueofFname>
这里我已经达到了tn,一旦我发现tn的值是“name1”, 那么我想通过查询节点路径来转到表名1 并且必须通过调用另一个模板(temp2)来传递它有一个参数。 我必须从name1表中获取fname的值。即,让它 是因为我已经将参数名称作为“pathValue”传递,其值为 ” ../name1" 。我想通过追加来获取路径中的值 / row / fname
然后当我看到tn的值为name3时,我再次打电话 与参数pathValue相同的模板为“../ name3”,与i一样 上面提到我必须在name3表中获取fname的值
请帮助遍历name1,name2和name3节点 基于报告表中'tn'的值。 有人可以帮助我如何设置我想要遍历的路径。 提前致谢
答案 0 :(得分:0)
您的输出与您的描述不完全一致。我猜你想做点什么:
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="*"/>
<xsl:key name="elem-by-name" match="*" use="name()" />
<xsl:template match="/root">
<xsl:for-each select="data/reportable/row" >
<xsl:choose>
<xsl:when test="contains(tn, 'name')">
<valueofFname>
<xsl:value-of select="key('elem-by-name', tn)/row/fname"/>
</valueofFname>
</xsl:when>
<xsl:when test="tn='currency'">
<curr>
<xsl:value-of select="value"/>
</curr>
</xsl:when>
</xsl:choose>
</xsl:for-each>
</xsl:template>
</xsl:stylesheet>
请注意,结果不是格式良好的XML文档(没有单个根元素)。