Próbuję napisać XSLT, który przekształci dokument XML, który mam do pliku CSV. Oto próbka xml:Jak napisać XSLT, aby przekształcić XML na 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>
Co chcę to XSLT, który będzie wyjście tak:
John,Doe,808 Elm St,Anywhere,NY
Jane,Noone,123 Some Rd,Anywhere,NY
Chyba mam kodu C poprawnego # zainicjowania transformacji, ale na wszelki wypadek I nie, oto ten kod, a także:
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);
}
}
}
Dzięki. Jest to przynajmniej w końcu pobieranie wartości, które chcę z mojego przykładowego pliku XML (chociaż formatowanie jest wciąż szalone). Z jakiegoś powodu dostaję przerwy liniowe i dziwne dodatkowe spacje, używając następującego XSLT: , , xsl: template> –