Ich versuche, eine XSLT zu schreiben, die ein XML-Dokument, das ich habe, in eine CSV-Datei umwandeln wird. Hier ist ein Beispiel der XML:Wie schreibe ich ein XSLT um XML in CSV zu transformieren?
<?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>
Was ich will, ist ein XSLT, die ausgegeben wird, wie so:
John,Doe,808 Elm St,Anywhere,NY
Jane,Noone,123 Some Rd,Anywhere,NY
Ich glaube, ich habe den C# -Code richtig, die Transformation zu initiieren, sondern nur für den Fall ich weiß nicht, hier ist der Code auch:
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);
}
}
}
Danke. Es ist zumindest endlich die Werte aus meiner XML-Beispieldatei abrufen (obwohl die Formatierung immer noch verrückt ist). Aus irgendeinem Grund bekomme ich Zeilenumbrüche und seltsame zusätzliche Leerzeichen mit der folgenden XSLT: , , xsl: template> –