所以,我有这个XML输入文档:
<?xml version="1.0" encoding="UTF-8"?>
<parent>
<childs>
<child ID="10" name="John"/>
<child ID="2" name="Marie"/>
<child ID="7" name="Joseph"/>
<child ID="5" name="Daisy"/>
</childs>
<childInfo>
<info childID="10" name="John" age="15" gender="M"/>
<info childID="2" name="Marie" age="20" gender="F"/>
<info childID="7" name="Joseph" age="17" gender="M"/>
</childInfo>
</parent>
还有第二个输入XML文档,可以使用document
函数来访问:
<?xml version="1.0" encoding="UTF-8"?>
<person>
<name>Daisy</name>
<age>20</age>
<gender>F</gender>
</person>
因此,我要使用从第二个(外部)XML文档中检索到的数据,在第一个输入XML文档中添加另一个<info>
元素
这是我要生成的输出XML:
<?xml version="1.0" encoding="UTF-8"?>
<parent>
<childs>
<child ID="10" name="John"/>
<child ID="2" name="Marie"/>
<child ID="7" name="Joseph"/>
<child ID="5" name="Daisy"/>
</childs>
<childInfo>
<info childID="10" name="John" age="15" gender="M"/>
<info childID="2" name="Marie" age="20" gender="F"/>
<info childID="7" name="Joseph" age="17" gender="M"/>
<child childID="5" name="Daisy" age="20" gender="F"/>
</childInfo>
</parent>
这是我的XSLT:
<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:xs="http://www.w3.org/2001/XMLSchema"
exclude-result-prefixes="xs"
expand-text="yes"
version="3.0">
<xsl:output indent="yes" />
<xsl:mode on-no-match="shallow-copy"/>
<xsl:variable name="externalDoc" select="document('externalStack.xml')"/>
<xsl:template match="parent/childInfo/info[last()]">
<xsl:variable name="nameOfChild" select="$externalDoc/person/name"/>
<xsl:variable name="idOfChild" select="parent/childs[@name = $nameOfChild]/@ID"/>
<xsl:next-match/>
<child>
<xsl:attribute name="childID">
<xsl:value-of select="$idOfChild" />
</xsl:attribute>
<xsl:attribute name="name">
<xsl:value-of select="$externalDoc/person/name"/>
</xsl:attribute>
<xsl:attribute name="age">
<xsl:value-of select="$externalDoc/person/age"/>
</xsl:attribute>
<xsl:attribute name="gender">
<xsl:value-of select="$externalDoc/person/gender"/>
</xsl:attribute>
</child>
</xsl:template>
</xsl:stylesheet>
我可以访问所有数据字段。问题是childID
属性。我想做的是获得子项ID
属性的值,其中name
属性等于第二个(外部)XML文档中的元素<name>
值。您可以看到我尝试使用两个<xsl:variables>
来执行此操作,其中一个(nameOfChild
)可以获取外部文件中<name>
元素的值,然后使用第二个({{1 }},则从idOfChild
元素中的属性ID
获取值,该属性的<child>
值等于name
变量值。
有人知道我该怎么做吗?因为似乎无法使用两个变量,所以
谢谢!
Alexandre Jacinto
答案 0 :(得分:1)
您正在这样做...
<xsl:variable name="idOfChild" select="parent/childs[@name = $nameOfChild]/@ID"/>
但这是一个相对表达式,因此它正在当前parent
节点下寻找一个info
节点。您应该这样做,以便检查整个文档(还要注意,您错过了对child
的引用)。
<xsl:variable name="idOfChild" select="/parent/childs/child[@name = $nameOfChild]/@ID"/>
或者,定义一个键
<xsl:key name="childs" match="child" use="@name" />
执行此操作...
<xsl:variable name="idOfChild" select="key('childs', $nameOfChild)/@ID"/>