如何编写 XSLT 将 XML 转换为 CSV?

Posted

技术标签:

【中文标题】如何编写 XSLT 将 XML 转换为 CSV?【英文标题】:How do I write an XSLT to transform XML to CSV? 【发布时间】:2010-10-31 10:37:49 【问题描述】:

我正在尝试编写一个 XSLT,它将我必须的 XML 文档转换为 CSV 文件。这是 XML 的示例:

<?xml version="1.0" encoding="utf-8"?>
<Import>
    <Users>
        <User ID="user_1" EmailAddress="johndoe@somewhere.com">
            <Contact FirstName="John" LastName="Doe" />
            <Address Street1="808 Elm St" City="Anywhere" State="NY" />
        </User>

        <User ID="user_2" EmailAddress="janenoone@somewhere.com">
            <Contact FirstName="Jane" LastName="Noone" />
            <Address Street1="123 Some Rd" City="Anywhere" State="NY" />
        </User>     
    </Users>
</Import>

我想要的是一个 XSLT,它会像这样输出:

John,Doe,808 Elm St,Anywhere,NY
Jane,Noone,123 Some Rd,Anywhere,NY

我认为我有正确的 C# 代码来启动转换,但以防万一我没有,这也是该代码:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Xml;
using System.Xml.Xsl;
using System.Configuration;

namespace UserTransform

    class Program
    
        static void Main(string[] args)
        
            string oldXML = ConfigurationSettings.AppSettings["XMLToBeTransformed"];
            string xsltLocation = ConfigurationSettings.AppSettings["XSLTfile"];
            string newCSV = ConfigurationSettings.AppSettings["NewCSVLocation"];

            XslCompiledTransform transform = new XslCompiledTransform();
            transform.Load(xsltLocation);
            transform.Transform(oldXML, newCSV);
        
    

【问题讨论】:

【参考方案1】:

我总是更喜欢让浏览器处理 XML 以减轻服务器的负担以进行要求更高的工作。也就是说,这里有一个示例 XSLT,它应该翻译您的 XML 并以 CSV 格式显示它,如上所示。

希望这个示例代码有帮助,如果没有,请告诉我。

<xsl:stylesheet version="1.0">
    <xsl:template match="/">
        <table>
            <xsl:for-each select="//User">
                <tr>
                    <td>
                        <xsl:value-of select="conat('[', @ID, ']')"/>
                        <xsl:value-of select="','"/>
                        <xsl:value-of select="Contact/@FirstName"/>
                        <xsl:value-of select="','"/>
                        <xsl:value-of select="Contact/@LastName"/>
                        <xsl:value-of select="','"/>
                        <xsl:value-of select="Address/@Street1"/>
                        <xsl:value-of select="','"/>
                        <xsl:value-of select="Address/@City"/>
                        <xsl:value-of select="','"/>
                        <xsl:value-of select="Address/@State"/>
                    </td>
                </tr>
             </xsl:for-each>
        </table>
     </xsl:template>
</xsl:stylesheet>

【讨论】:

很抱歉,这行不通,因为您的代码会多出三个换行符。考虑使用 作为逗号。 感谢您的评论,阿拉马尔。我已经在我的博客上发布了整个解决方案,如果您仍然遇到任何换行符,请查看并告诉我。我还解释了一些你可能想知道的关于输出的事情。这是帖子:jroller.com/evans/entry/using_xslt_to_transform_xml 最好将 ',' 和 '[' 放在它们自己的 xsl:value-of 元素中。这将使您可以根据需要对其进行格式化,而不会引入额外的换行符。其实……我会把它编辑成那种格式。 我认为你的意思是在第一个 xsl 中 concat 不是 conat:value-of ` ` 【参考方案2】:

根据我的经验,我一直在客户端而不是服务器端使用 XSLT,这似乎是您使用 C# 尝试的方式

【讨论】:

嗯,xslt 是从 exe 中使用的……但总的来说,在服务器上使用 xslt更安全……尝试编写非常痛苦xslt 处理每个浏览器变体的 xslt 处理器。 也许不是一个很有帮助的答案...我当然在 Java 中使用 XSLT 服务器端来转换 XML 数据。快速、高效、标准。如果您的客户不能使用 javascript 怎么办? 也许我对 XSLT 的含义感到困惑,它是所有 XML 转换的保护伞吗?例如,如果我使用 php 的 SimpleXML 库来解析一些 XML 并将其作为 html、CSV 或任何被认为是 XSLT 的东西输出?我认为 XSLT 是它自己的标记/语言 XSLT 是一种严格定义的语言,具有数十种兼容的实现。【参考方案3】:

创建一个匹配所有用户的模板,然后按照你想要的顺序拉出你需要的信息:

<xsl:template match="//User">
  <xsl:value-of select="Contact/@FirstName"/>,
  <xsl:value-of select="Contact/@LastName"/>,
  <!--etc-->
</xsl:template>

显然,您需要确保按照您希望的方式处理空格,并在正确的位置添加换行符。我将把这个作为练习留给读者。

【讨论】:

谢谢。它至少最终从我的示例 XML 文件中检索到我想要的值(尽管格式仍然很疯狂)。出于某种原因,我使用以下 XSLT 得到换行符和奇怪的额外空格: w3.org/1999/XSL/Transform">

以上是关于如何编写 XSLT 将 XML 转换为 CSV?的主要内容,如果未能解决你的问题,请参考以下文章

如何使用 XSLT 2.0 将 csv 文件转换为结构化 XML 文件?

使用 Python 或 XSLT 将复杂的 XML 转换为 CSV

使用XSLT将XML转换为csv

使用 XSLT 将 XML 转换为 CSV

使用 XSLT 将 XML 转换为 CSV

使用 XSLT 将 XML 转换为 CSV,用于在单个标记中以空格分隔的多个记录