Требуется преобразование XSLT для преобразования входного XML в выходной XML

#xml #xslt

#xml #xslt

Вопрос:

привет,

Я хочу преобразовать входной XML в выходной XML с помощью XSLT.

Входной 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>
  

Комментарии:

1. Не могли бы вы отформатировать свой вопрос так, чтобы можно было прочитать XML-схему и предоставить то, что вы уже пробовали

Ответ №1:

Это преобразование:

 <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. Использование этого кода: var myXslTrans = new XslCompiledTransform(); myXslTrans.Load("Files/NaughtyXSLT_Transform.xsl"); myXslTrans.Transform("Files/NaughtyXSLT_InputXML.xml","NaughtyXSLT_OutputXML.xml"); Не работает, боже, я по какой-то причине не могу отредактировать этот комментарий!

Ответ №2:

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

Хотя и не тестировалось.

Комментарии:

1. В предоставленном исходном XML-документе нет элемента с именем entry .

2. Это было <AllFields> ... </entry> так, что я выбрал entry . Спасибо, обновлено.