Как я пишу XSLT для преобразования XML к CSV?







jsfiddle = http://jsfiddle.net/v4auT/

11
задан KyleMit 25 July 2014 в 17:37
поделиться

3 ответа

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

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

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

17
ответ дан 3 December 2019 в 05:36
поделиться

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

-3
ответ дан 3 December 2019 в 05:36
поделиться

Я всегда предпочитаю позволить браузеру обрабатывать 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>
7
ответ дан 3 December 2019 в 05:36
поделиться
Другие вопросы по тегам:

Похожие вопросы: