一个XML文件
<x1>
<x2>xyz</x2>
<x3>xy</x3>
<x4>z</x4>
<x5>123</x5>
</x1>
另一个XML
<?xml version="1.0" standalone="yes"?>
<DocumentElement>
<c>
<ID>1</ID>
<XMLFieldName>UserDetails</XMLFieldName>
</c>
<c>
<ID>2</ID>
<XMLFieldName>UserName</XMLFieldName>
</c>
<c>
<ID>3</ID>
<XMLFieldName>FirstName</XMLFieldName>
</c>
<c>
<ID>4</ID>
<XMLFieldName>LastName</XMLFieldName>
</c>
<c>
<ID>5</ID>
<XMLFieldName>EmployeeID</XMLFieldName>
</c>
</DocumentElement>
我想将结果XML作为
<UserDetails>
<UserName>xyz</UserName>
<FirstName>xy</FirstName>
<LastName>z</LastName>
<EmployeeID>123</EmployeeID>
</UserDetails>
更多信息:实际上,第1和第2个文件在DB Table中作为XML dataType。 我只需要一个XSLT来获取第3个XML和X1,x2 ....节点基于标签ID。
ThanQ in Advance ..: - )
答案 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"/>
<!--
Pass the name of the other XML file as a parameter to the transformation;
x1.xml is used by default
-->
<xsl:param name="x1" select="'x1.xml'"/>
<xsl:template match="/">
<!-- Only apply the first <c> element -->
<xsl:apply-templates
select="DocumentElement/c[XMLFieldName = 'UserDetails']"/>
</xsl:template>
<xsl:template match="c[XMLFieldName = 'UserDetails']">
<!-- Use the value of the XMLFieldName element as the element name -->
<xsl:element name="{XMLFieldName}">
<!-- Apply following <c> siblings -->
<xsl:apply-templates select="following-sibling::c"/>
</xsl:element>
</xsl:template>
<xsl:template match="c">
<!-- Save the value of the ID child of current <c> element -->
<xsl:variable name="id" select="ID"/>
<xsl:element name="{XMLFieldName}">
<!--
Get the value of the element in x1.xml that has the same number in its
element name as the value of the <ID> child of this <c> element
-->
<xsl:value-of
select="document($x1)/*/*[substring-after(local-name(), 'x') = $id]"/>
</xsl:element>
</xsl:template>
</xsl:stylesheet>
<?xml version="1.0" standalone="yes"?>
<DocumentElement>
<c>
<ID>1</ID>
<XMLFieldName>UserDetails</XMLFieldName>
</c>
<c>
<ID>2</ID>
<XMLFieldName>UserName</XMLFieldName>
</c>
<c>
<ID>3</ID>
<XMLFieldName>FirstName</XMLFieldName>
</c>
<c>
<ID>4</ID>
<XMLFieldName>LastName</XMLFieldName>
</c>
<c>
<ID>5</ID>
<XMLFieldName>EmployeeID</XMLFieldName>
</c>
</DocumentElement>
<x1>
<x2>xyz</x2>
<x3>xy</x3>
<x4>z</x4>
<x5>123</x5>
</x1>
<?xml version="1.0" encoding="utf-8"?>
<UserDetails>
<UserName>xyz</UserName>
<FirstName>xy</FirstName>
<LastName>z</LastName>
<EmployeeID>123</EmployeeID>
</UserDetails>