Avatar billede andersknudsen Nybegynder
23. december 2010 - 14:09 Der er 1 kommentar og
1 løsning

xml -> csv

Hej eksperter

Jeg har noget xml ala:
<?xml version="1.0" encoding="utf-8" ?>
<batch>
  <sagsliste>
    <sag x="1" y="2">
      <pris p="100"/>
    </sag>
    <sag x="3" y="4">
      <pris p="200"/>
      <pris p="150"/>
    </sag>
  </sagsliste>
</batch>

som jeg gerne vil have konverteret til:
x;y;p
1;2;100
3;4;200
3;4;150

Puha - det er for svært for mig :-). Er der nogen der vil hjælpe?

Hilsen Anders
Avatar billede andersknudsen Nybegynder
23. december 2010 - 16:05 #1
jeg er der næsten men kan ikke få det sidste på plads:

<?xml version="1.0"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
  <xsl:output method="text"/>
  <xsl:template match="/">
    <xsl:apply-templates select="//sagsliste"></xsl:apply-templates>
  </xsl:template>
  <xsl:template match="sagsliste">
    <xsl:variable name="nbNested" select="count(./sag/pris)"/>
    <xsl:call-template name="addRow">
      <xsl:with-param name="curPos" select="1"/>
      <xsl:with-param name="maxPos" select="$nbNested"/>
    </xsl:call-template>
  </xsl:template>
  <xsl:template name="addRow">
    <xsl:param name="curPos"/>
    <xsl:param name="maxPos"/>
    <xsl:if test="$maxPos >= $curPos">
      <xsl:value-of select="@x"/>
      <xsl:text>,</xsl:text>
      <xsl:value-of select="./pris[$curPos]"/>
      <xsl:text>,</xsl:text>
      <xsl:text>;</xsl:text>
      <xsl:call-template name="addRow">
        <xsl:with-param name="curPos" select="$curPos + 1"/>
        <xsl:with-param name="maxPos" select="$maxPos"/>
      </xsl:call-template>
    </xsl:if>
  </xsl:template>
</xsl:stylesheet>
Avatar billede tjens Nybegynder
23. december 2010 - 23:48 #2
<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="text"/>

<xsl:template match="/batch">
  <xsl:for-each select="sagsliste/sag">
    <xsl:variable name="x" select="@x"/>
    <xsl:variable name="y" select="@y"/>

    <xsl:for-each select="pris">
      <xsl:value-of select="$x" />
      <xsl:text>;</xsl:text>
      <xsl:value-of select="$y" />
      <xsl:text>;</xsl:text>
      <xsl:value-of select="@p" />
      <xsl:text><![CDATA[
]]></xsl:text>

    </xsl:for-each>

  </xsl:for-each>
</xsl:template>
</xsl:stylesheet>

Test det her: http://tjens.dk/eksperten/927135/
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview
Kategori
Kurser inden for grundlæggende programmering

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester