Как мне написать XSLT для преобразования XML в CSV? - PullRequest
11 голосов
/ 04 июня 2009

Я пытаюсь написать 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);
        }
    }
}

Ответы [ 3 ]

17 голосов
/ 04 июня 2009

Создайте шаблон, соответствующий всем пользователям, затем извлеките необходимую информацию в нужном вам порядке:

<xsl:template match="//User">
  <xsl:value-of select="Contact/@FirstName"/>,
  <xsl:value-of select="Contact/@LastName"/>,
  <!--etc-->
</xsl:template>

Очевидно, что вам нужно убедиться, что пробелы обрабатываются так, как вы хотите, с символами новой строки в нужных местах. Я оставлю это как упражнение читателю.

7 голосов
/ 20 июня 2009

Я всегда предпочитаю, чтобы браузер обрабатывал 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>
0 голосов
/ 04 июня 2009

По моему опыту, я всегда использовал XSLT на стороне клиента, а не на стороне сервера, что вы пытаетесь использовать в C #

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...