Как написать XSLT для преобразования XML в CSV?
Я пытаюсь написать XSLT, который преобразует XML-документ, который у меня есть в файл CSV. Здесь образец XML:
<?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
Я думаю, что у меня правильный код С#, чтобы инициировать преобразование, но на всякий случай я этого не делаю:
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
Создайте шаблон, соответствующий всем пользователям, затем вытащите необходимую информацию в том порядке, в котором вы хотите:
<xsl:template match="//User">
<xsl:value-of select="Contact/@FirstName"/>,
<xsl:value-of select="Contact/@LastName"/>,
<!--etc-->
</xsl:template>
Очевидно, вам нужно убедиться, что пробелы обрабатываются так, как вы хотите, с новыми символами в правильных местах. Я оставлю это как упражнение для читателя.
Ответ 2
Я всегда предпочитаю, чтобы браузер обрабатывал 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>
Ответ 3
По моему опыту, я всегда использовал XSLT на стороне клиента, а не на стороне сервера, что вы пытаетесь сделать с помощью С#