HI,
我希望使用XSLT将输入XML转换为OUTput XML。
输入XML如下
<ALLFields id="0001">
<field name="ComputerName">ABC</field>
<field name="ComputerType">Windows</field>
<field name="DatabaseName" />
<field name="CPULevel">10</field>
</ALLFields>
OUTPUT XML我需要的是
<entry id="0001">
<ComputerName>ABC</ComputerName>
<ComputerType>Windows</ComputerType>
<DatabaseName />
<CPULevel>10</CPULevel>
</entry>
答案 0 :(得分:3)
此转化:
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output omit-xml-declaration="yes" indent="yes"/>
<xsl:strip-space elements="*"/>
<xsl:template match="ALLFields">
<entry id="{@id}">
<xsl:apply-templates select="node()"/>
</entry>
</xsl:template>
<xsl:template match="field">
<xsl:element name="{@name}">
<xsl:apply-templates/>
</xsl:element>
</xsl:template>
</xsl:stylesheet>
应用于提供的XML文档(更正为格式良好):
<ALLFields id="0001">
<field name="ComputerName">ABC</field>
<field name="ComputerType">Windows</field>
<field name="DatabaseName" />
<field name="CPULevel">10</field>
</ALLFields>
会产生想要的正确结果:
<entry id="0001">
<ComputerName>ABC</ComputerName>
<ComputerType>Windows</ComputerType>
<DatabaseName/>
<CPULevel>10</CPULevel>
</entry>
答案 1 :(得分:0)
<xsl:template match="AllFields">
<entry id="{@id}">
<xsl:for-each select="field">
<xsl:element name="{@name}">
<xsl:value-of select="text()"/>
</xsl:element>
</xsl:for-each>
</entry>
</xsl:template>
虽未经过测试。