0

我有 3 个不同的 XML 文件。其中一些列是常见的,而有些则不是。并且它们的 ordinalPosition 正在发生变化。每次,我都会在我的 ftp 中获取新文件,需要一一读取并加载到系统中。但我不知道文件的列名。

  XML 1 :
  <?xml version="1.0" encoding="UTF-8"?>
    <SourceFile>
       <Data>
         <CustNo>126</CustNo>
         <Gender/>
         <isActive>0</isActive>
         <Email/>
       </Data>
    </SourceFile>   

XML 2 :
<?xml version="1.0" encoding="UTF-8"?>
 <SourceFile>
   <Data>
    <CustNo>124</CustNo>
    <Phone/>
    <Country/>
    <isActive>1</isActive>
   </Data>
 </SourceFile> 

XML 3:
<?xml version="1.0" encoding="UTF-8"?>
 <SourceFile>
   <Data>
    <KeyId>123</KeyId>
    <FirstName/>
    <LastName/>
    <Email/>  
    <isActive>0</isActive>
   </Data>
 </SourceFile> 

我对 XSLT 很陌生。每当文件到达我的 ftp 时,我想生成以下输出。

  Result for XML 1 :
  <?xml version="1.0" encoding="UTF-8"?>
    <SourceFile>
      <Data>
        <KeyID>124</KeyID>  <!-- CustNo will be mapped to KeyId -->
        <FirstName/>
        <LastName/>
        <Email/> 
        <Phone/>
        <Country/>
        <isActive>0</isActive> 
      </Data>
    </SourceFile> 

非常感谢, 穆罕默德

4

2 回答 2

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

<xsl:template match="/SourceFile">
    <xsl:copy>
        <xsl:for-each select="Data">
            <xsl:copy>
                <KeyID>
                    <xsl:value-of select="CustNo | KeyId"/>
                </KeyID>
                <FirstName>
                    <xsl:value-of select="FirstName"/>
                </FirstName>
                <LastName>
                    <xsl:value-of select="LastName"/>
                </LastName>
                <Email> 
                    <xsl:value-of select="Email"/>
                </Email> 
                <Phone>
                    <xsl:value-of select="Phone"/>
                </Phone>
                <Country>
                    <xsl:value-of select="Country"/>
                </Country>
                <isActive>
                    <xsl:value-of select="isActive"/>
                </isActive> 
            </xsl:copy>
        </xsl:for-each>
    </xsl:copy>
</xsl:template>

</xsl:stylesheet>
于 2016-10-07T10:03:24.057 回答
0

一种尝试是:

<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">

    <xsl:output method="xml" indent="yes"/>

    <xsl:template match="Data">
       <xsl:copy>
           <KeyID><xsl:value-of select="CustNo | KeyId"/></KeyID>
           <FirstName><xsl:value-of select="FirstName"/></FirstName>
           <Email><xsl:value-of select="Email"/></Email>
           <Phone><xsl:value-of select="Phone"/></Phone>
           <Country><xsl:apply-templates select="Country"/></Country>
           <isActive><xsl:value-of select="isActive"/></isActive>
       </xsl:copy>
    </xsl:template>

    <xsl:template match="Country">
        <xsl:value-of select="."/>
    </xsl:template>

    <xsl:template match="@* | node()">
        <xsl:copy>
            <xsl:apply-templates select="@* | node()"/>
        </xsl:copy>
    </xsl:template>

</xsl:stylesheet>

解释:

在元素上Data,您始终会创建预期的结果。Like KeyID, FirstName, and so on.. Whenever the select of either <xsl:value-ofor <xsl:apply-templatesmatches, you get the content of node.

<xsl:value-of />只返回一个元素的字符串。

<xsl:apply-templates />最终也会执行其他模板规则!例如,如果您有子节点,这很重要。您可以在 element 的示例中看到这一点Country

XML 和 XSLT 区分大小写。

于 2016-10-07T10:03:35.343 回答