【问题标题】:XSLT transformation to get Attribute ValuesXSLT 转换以获取属性值
【发布时间】:2013-09-16 14:56:46
【问题描述】:

我有以下 XML 文件:

<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<DatDtl xmlns="http://ups.com/ttg/cache/country">
<CnyDtl>
<Cny TslLguCd="001" CnyCd="00" Cny2Cd="DNA" Cny3Cd="000" CnyNa="Data Not Available" CnyOflNa="Data Not Available" RecEffSttDt="2010-12-31" RecEffEndDt="2099-12-31" RecUdtTs="2012-07-27 15:35:08.352773"/>
<Cny TslLguCd="001" CnyCd="96" Cny2Cd="OTH" Cny3Cd="996" CnyNa="Other" CnyOflNa="Other" RecEffSttDt="2010-12-31" RecEffEndDt="2099-12-31" RecUdtTs="2012-07-27 15:35:14.291605"/>
</CnyDtl>
</DatDtl>

我想将其转换为仅包含 CnyCd 和 CnyNa 属性值的 CSV 文件。我编写了以下 XSLT 来提取这两个值:

<

?xml version="1.0" encoding="ISO-8859-1"?>
    <xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
      <xsl:template match="/">
         <xsl:for-each select="CnyDtl/Cny">
         <xsl:value-of select="@CnyNa"/>
<xsl:value-of select="@CnyCd"/>
         </xsl:for-each>
        </xsl:template>
    </xsl:stylesheet>

但我总是会出错。什么是正确的 XSLT 转换?

【问题讨论】:

  • 您好,您必须先匹配“DatDtl”,然后才能匹配每个“CnyDtl/Cny”。最好的问候,彼得
  • 不要告诉我们您遇到了错误而不告诉我们您遇到了什么错误。它们可能对您没有意义,但它们可能对回答您问题的人有意义。

标签: xml xslt csv transformation


【解决方案1】:

首先在你的样式表中你忘了提到根元素&lt;DatDtl&gt;。另外不要忘记在样式表中声明命名空间。

如果您使用以下 XSLT 1.0 样式表:

<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:mypref="http://ups.com/ttg/cache/country">
    <xsl:output method="text" />

    <xsl:variable name="FS"> <!-- Field seperator -->
        <xsl:text>;</xsl:text>
    </xsl:variable>
    <xsl:variable name="LT"> <!-- Line terminator -->
        <xsl:text>&#13;</xsl:text>
    </xsl:variable>

    <xsl:template match="/mypref:DatDtl">
        <xsl:for-each select="mypref:CnyDtl/mypref:Cny">
            <xsl:value-of select="@CnyNa"/>
            <xsl:value-of select=" $FS" />
            <xsl:value-of select="@CnyCd"/>
            <xsl:value-of select="$LT" />
        </xsl:for-each>
    </xsl:template>
</xsl:stylesheet>

它将给出以下输出:

Data Not Available;00
Other;96

【讨论】:

    猜你喜欢
    • 2017-03-29
    • 2021-12-20
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2013-08-15
    • 1970-01-01
    • 2017-04-22
    相关资源
    最近更新 更多