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][CSV]Transformer du XML en CSV et inversement !


Sujet :

XML/XSL et SOAP

  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    5
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 5
    Points : 5
    Points
    5
    Par défaut [XML][CSV]Transformer du XML en CSV et inversement !
    Bonjour,

    Je voudrais savoir s'il existe des utilitaires pilotables par du code pour générer un fichier CSV à partir d'un fichier XML (comme ce que fait Excel) et inversement.

    Est-ce que quelqu'un aurait eu cette problématique à résoudre ?

    Merci pour votre aide...

  2. #2
    Membre éclairé
    Homme Profil pro
    Consultant ERP
    Inscrit en
    Février 2004
    Messages
    644
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Consultant ERP

    Informations forums :
    Inscription : Février 2004
    Messages : 644
    Points : 785
    Points
    785
    Par défaut
    du XML vers CSV, je pense que c'est faisable du fait que les sorties possibles de xslt peuvent être du text, du xml ou du html.
    Par contre, bonjour l'amusement pour écrire un tel script.

    Par contre, utiliser un langage de script pour te faire la chose est très facile.

    Si tu es intéressé, dis le moi.
    Nul ne peut mieux connaitre la connaissance qu'elle-même.

  3. #3
    Membre éprouvé
    Profil pro
    Responsable Dev
    Inscrit en
    Décembre 2003
    Messages
    788
    Détails du profil
    Informations personnelles :
    Localisation : France, Vendée (Pays de la Loire)

    Informations professionnelles :
    Activité : Responsable Dev

    Informations forums :
    Inscription : Décembre 2003
    Messages : 788
    Points : 1 063
    Points
    1 063
    Par défaut un exemple
    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
     
    <racine>
        <elt>
                 <name>tutu0</name>
                 <forname>titi0</forname>
        </elt>
        <elt>
                 <name>tutu1</name>
                 <forname>titi1</forname>
        </elt>
        <elt>
                 <name>tutu2</name>
                 <forname>titi2</forname>
        </elt>
        <elt>
                 <name>tutu3</name>
                 <forname>titi3</forname>
        </elt>
    </racine>
    le xslt permettant d'obtenir un csv
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    <xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
    	<xsl:output method="txt"/>
    	<xsl:strip-space elements="*"/>
     
    	<xsl:template match="elt">
    			<xsl:apply-templates select="./name"/>;<xsl:apply-templates select="./forname"/>;
    	</xsl:template>
     
    </xsl:stylesheet>
    et voila cela n'est pas si difficile surtout que tu peux écrire une feuille de style qui génère la feuille de style permettant de passer au format csv

  4. #4
    Membre éclairé
    Homme Profil pro
    Consultant ERP
    Inscrit en
    Février 2004
    Messages
    644
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Consultant ERP

    Informations forums :
    Inscription : Février 2004
    Messages : 644
    Points : 785
    Points
    785
    Par défaut
    La question possède à moitié sa réponse étant donné que notre ami désire générer du XML à partir d'un CSV.

    Une idée ?
    Nul ne peut mieux connaitre la connaissance qu'elle-même.

  5. #5
    Expert éminent
    Avatar de GrandFather
    Inscrit en
    Mai 2004
    Messages
    4 587
    Détails du profil
    Informations personnelles :
    Âge : 54

    Informations forums :
    Inscription : Mai 2004
    Messages : 4 587
    Points : 7 103
    Points
    7 103
    Par défaut
    Bonjour,

    si google est resté muet à ce sujet, il ne te reste plus qu'à l'écrire toi-même... Ce qui ne devrait pas être très difficile, quel que soit le langage.
    FAQ XML
    ------------
    « Le moyen le plus sûr de cacher aux autres les limites de son savoir est de ne jamais les dépasser »
    Giacomo Leopardi

  6. #6
    Membre éprouvé
    Profil pro
    Responsable Dev
    Inscrit en
    Décembre 2003
    Messages
    788
    Détails du profil
    Informations personnelles :
    Localisation : France, Vendée (Pays de la Loire)

    Informations professionnelles :
    Activité : Responsable Dev

    Informations forums :
    Inscription : Décembre 2003
    Messages : 788
    Points : 1 063
    Points
    1 063
    Par défaut
    En effet je complète ma réponse:
    un fichier csv:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    "a";"b";"c"
    "1";"2";"3"
    "1";"2";"3"
    un bout de code python
    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
     
    from xml.dom.minidom import Document
    import csv
     
    cr = csv.reader(open("/home/fraoustin/sample.csv","rb"), delimiter=";")
    xmldoc = Document()
    xmltag = xmldoc.createElement("root")
    x=0
    for i in cr:
    	xmlchild = xmldoc.createElement("child")
    	for j in i:
    		xmlchild2 = xmldoc.createElement("elt%s"%x)		
    		xmlchild2.appendChild(xmldoc.createTextNode(j))
    		xmlchild.appendChild(xmlchild2)
    		x=x+1
            x=0
    	xmltag.appendChild(xmlchild)
    xmldoc.appendChild(xmltag)
    print xmldoc.toxml()
    et on obtient
    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
     
    <?xml version="1.0" ?>
    <root>
    	<child>
    		<elt0>a</elt0>
    		<elt1>b</elt1>
    		<elt2>c</elt2>
    	</child>
    	<child>
    		<elt0>1</elt0>
    		<elt1>2</elt1>
    		<elt2>3</elt2>
    	</child>
    	<child>
    		<elt0>1</elt0>
    		<elt1>2</elt1>
    		<elt2>3</elt2>
    	</child>
    </root>

  7. #7
    Membre éclairé
    Homme Profil pro
    Consultant ERP
    Inscrit en
    Février 2004
    Messages
    644
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Consultant ERP

    Informations forums :
    Inscription : Février 2004
    Messages : 644
    Points : 785
    Points
    785
    Par défaut
    merci pour notre ami tgarcia.

    on peut fermer le thread ?
    Nul ne peut mieux connaitre la connaissance qu'elle-même.

Discussions similaires

  1. [XSLT 1.0] CSV tree to XML
    Par ttttnht dans le forum XSL/XSLT/XPATH
    Réponses: 5
    Dernier message: 07/03/2011, 13h22
  2. Transformer un XML en "n" fichier XML
    Par argoet dans le forum XSL/XSLT/XPATH
    Réponses: 6
    Dernier message: 26/02/2011, 10h13
  3. Réponses: 1
    Dernier message: 11/07/2007, 10h25
  4. Réponses: 2
    Dernier message: 06/07/2006, 08h47
  5. [XML][XSLT] transformer le xml en binaire via une xslt
    Par chama dans le forum XSL/XSLT/XPATH
    Réponses: 2
    Dernier message: 25/07/2005, 11h42

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