需要 XSLT 转换将输入 XML 转换为输出 XML

发布于 2024-10-30 19:45:03 字数 576 浏览 1 评论 0原文

您好,

我希望使用 XSLT 将输入 XML 转换为输出 XML。

输入 XML 如下所示

<ALLFields id="0001">
  <field name="ComputerName">ABC</field>
  <field name="ComputerType">Windows</field>
  <field name="DatabaseName" />
  <field name="CPULevel">10</field>
</ALLFields>

输出 XML 我需要的是

<entry id="0001">
<ComputerName>ABC</ComputerName>
<ComputerType>Windows</ComputerType>
<DatabaseName />
<CPULevel>10</CPULevel>
</entry>

HI,

I am looking to convert input XML to OUTput XML using XSLT.

Input XML is as below

<ALLFields id="0001">
  <field name="ComputerName">ABC</field>
  <field name="ComputerType">Windows</field>
  <field name="DatabaseName" />
  <field name="CPULevel">10</field>
</ALLFields>

OUTPUT XML what i need is

<entry id="0001">
<ComputerName>ABC</ComputerName>
<ComputerType>Windows</ComputerType>
<DatabaseName />
<CPULevel>10</CPULevel>
</entry>

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

勿忘初心 2024-11-06 19:45:03

此转换

<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>

This transformation:

<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>

when applied on the provided XML document (corrected to be well-formed):

<ALLFields id="0001">
    <field name="ComputerName">ABC</field>
    <field name="ComputerType">Windows</field>
    <field name="DatabaseName" />
    <field name="CPULevel">10</field>
</ALLFields>

produces the wanted, correct result:

<entry id="0001">
   <ComputerName>ABC</ComputerName>
   <ComputerType>Windows</ComputerType>
   <DatabaseName/>
   <CPULevel>10</CPULevel>
</entry>
冷夜 2024-11-06 19:45:03
<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>

虽然没有测试过。

<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>

Not tested though.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文