我正試圖編寫一個XSLT,它將轉換我必須轉換爲CSV文件的XML文檔。下面是XML的一個樣本:如何編寫XSLT以將XML轉換爲CSV?
<?xml version="1.0" encoding="utf-8"?>
<Import>
<Users>
<User ID="user_1" EmailAddress="[email protected]">
<Contact FirstName="John" LastName="Doe" />
<Address Street1="808 Elm St" City="Anywhere" State="NY" />
</User>
<User ID="user_2" EmailAddress="[email protected]">
<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);
}
}
}
謝謝。至少最終從我的示例XML文件中檢索出我想要的值(儘管格式仍然很瘋狂)。出於某種原因,我在使用以下XSLT時出現換行符和奇怪的額外空格: 的 , 的 , XSL:模板> –
2009-06-04 19:03:50