我正在尝试编写一个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);
}
}
}
答案 0 :(得分:17)
创建一个匹配所有用户的模板,然后按照您想要的顺序提取所需的信息:
<xsl:template match="//User">
<xsl:value-of select="Contact/@FirstName"/>,
<xsl:value-of select="Contact/@LastName"/>,
<!--etc-->
</xsl:template>
显然,您需要确保按照您希望的方式处理空格,并在正确的位置添加换行符。我会将此作为练习留给读者。
答案 1 :(得分:7)
我总是喜欢让浏览器处理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>
答案 2 :(得分:-3)
根据我的经验,我总是在服务器端的客户端使用XSLT,而这似乎是您尝试使用C#