IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

XML/XSL et SOAP Discussion :

[xml]Conversion d'une structure xml en csv


Sujet :

XML/XSL et SOAP

  1. #1
    Futur Membre du Club
    Inscrit en
    Juillet 2005
    Messages
    8
    Détails du profil
    Informations forums :
    Inscription : Juillet 2005
    Messages : 8
    Points : 6
    Points
    6
    Par défaut [xml]Conversion d'une structure xml en csv
    Qui connait un outil pouvant mettre à plat une structure xml en csv par exemple avec les champs triés toujours dans le même ordre:

    par exemple

    <liste_cli>
    <cli name="cli1">
    <attributcli name="att1"> xx11</attributcli>
    <attributcli name="att2"> xx12</attributcli>
    ...
    </cli>
    <cli name="cli2">
    <attributcli name="att2"> xx22</attributcli>
    <attributcli name="att1"> xx21</attributcli>
    ...
    </cli>
    ....
    </list_cli>

    donnerait
    xx11, xx12, ...
    xx21, xx22, ...
    ....

    sûr qu'un prog xsl peut le faire aussi mais ce qui m'ennuie c'est le tri des données en sortie... A moins que quelqu'un aurait une idée?

  2. #2
    Membre averti
    Profil pro
    Inscrit en
    Janvier 2003
    Messages
    284
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2003
    Messages : 284
    Points : 349
    Points
    349
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
     
    <?xml version="1.0" encoding="ISO-8859-1"?>
    <xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
    <xsl:output method="text" indent="no" encoding="ISO-8859-1" version="1.0"/>
    <xsl:template match="/">
    <xsl:apply-templates select="liste_cli"/>
    </xsl:template>
    <xsl:template match="liste_cli">
    <xsl:apply-templates select="cli"/>
    </xsl:template>
    <xsl:template match="cli">
    <xsl:for-each select="attributcli">
    <xsl:sort select="@name"/>
    <xsl:value-of select="$Value"/>
    <xsl:if test="position() != last()">, </xsl:if>
    </xsl:for-each>
    <CRLF> 
    </CRLF>
    </xsl:template>
    </xsl:stylesheet>

  3. #3
    Futur Membre du Club
    Inscrit en
    Juillet 2005
    Messages
    8
    Détails du profil
    Informations forums :
    Inscription : Juillet 2005
    Messages : 8
    Points : 6
    Points
    6
    Par défaut
    Merci pour la réponse
    ça marche super bien,

    j'ai cependant remplacé
    '$Value' par '.' et

    <CRLF>
    </CRLF>
    par
    <xsl:text>
    </xsl:text>

    je m'étais orienté sur un programme un peut différent puisque mon objectif final est la comparaison de fichiers de log :

    <xsl:output method="text" indent="yes"/>

    <xsl:template match="ListeClient">
    <xsl:copy>
    <xsl:apply-templates select="Client"/>
    </xsl:copy>
    </xsl:template>

    <xsl:template match="Client">
    <xsl:text>Client</xsl:text>
    <xsl:text>
    </xsl:text>
    <xsl:apply-templates select="AttributClient/@nomAttribut">
    <xsl:sort />
    </xsl:apply-templates>
    </xsl:template>

    <xsl:template match="AttributClient/@nomAttribut">
    <xsl:text> - </xsl:text>
    <xsl:apply-templates select=".."/>
    <xsl:text> (</xsl:text>
    <xsl:value-of select="."/>
    <xsl:text>)
    </xsl:text>
    </xsl:template>

    </xsl:stylesheet>
    [/quote]

  4. #4
    Futur Membre du Club
    Inscrit en
    Juillet 2005
    Messages
    8
    Détails du profil
    Informations forums :
    Inscription : Juillet 2005
    Messages : 8
    Points : 6
    Points
    6
    Par défaut
    A supposer que dans la définition de 'cli' on ait plusieurs elements autre que "attributcli" est -il possible de généraliser la définition du tri de manière à l'effectuer pour chacun des éléments et cela quelque soit le nombre d'élément et sans avoir une connaissance particulière de leur nom.

    La réponse est surement triviale...

    En compliquant un peu plus on peut aussi ajouter un tri sur les attributs afin d'obtenir toutes les données triées et pouvoir comparer de manière fiable toute la structure...

    J'avoue qu'à première vue je cale.. soit j'ai le résultat correct pour un tri, soit... enfin ça ne marche pas comme je le souhaite

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 7
    Dernier message: 12/01/2011, 03h58
  2. [Structure] Aide sur une structure XML (et le vocabulaire associé)
    Par projetdk40 dans le forum XML/XSL et SOAP
    Réponses: 2
    Dernier message: 14/02/2007, 10h38
  3. Traitement d'une structure XML qui change
    Par moook dans le forum Modules
    Réponses: 6
    Dernier message: 17/10/2006, 14h24
  4. Recherche dans une structure XML::Simple
    Par nicolargo dans le forum Modules
    Réponses: 1
    Dernier message: 04/09/2006, 19h17
  5. Enlver un noeud dans une structure XML
    Par Sharingan dans le forum ASP
    Réponses: 4
    Dernier message: 20/12/2004, 08h08

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo