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

Langage Perl Discussion :

[XML] Conversion XML en CSV


Sujet :

Langage Perl

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    42
    Détails du profil
    Informations personnelles :
    Localisation : France, Sarthe (Pays de la Loire)

    Informations forums :
    Inscription : Avril 2006
    Messages : 42
    Points : 39
    Points
    39
    Par défaut [Résolu] [XML] Conversion XML en CSV
    Bonjour,

    Je souhaite faire une conversion d'un fichier XML en CSV, j'ai lu pas mal d'article sur le net mais ils sont tous plus compliqués les uns que les autres.

    Voici le script :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    $xml	= new XML::Simple;
    $data 	= $xml->XMLin($FichierXML);
     
    $Questions = $data->{'Questions'} ;
    $TabQuestion = $Questions->{'Question'};
     
    print Dumper($TabQuestion) ;
    Le résultat de ce code est :
    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
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
     
    $VAR1 = [
              {
                'NombreReponses' => '1',
                'EtapeReponses' => '1',
                'Reponses' => {
                              'Reponse' => {
                                           'CodeLieuDeces' => '27000',
                                           'NumeroActeDeces' => '129/3',
                                           'DateNaissance' => {
                                                              'JourNaissance' => '25',
                                                              'MoisNaissance' => '10',
                                                              'AnneeNaissance' => '1956'
                                                            },
                                           'Sexe' => 'M',
                                           'DateDeces' => {
                                                          'MoisDeces' => '04',
                                                          'AnneeDeces' => '2003',
                                                          'JourDeces' => '26'
                                                        },
                                           'Prenoms' => {
                                                        'Prenom2' => 'MICHEL',
                                                        'Prenom1' => 'JOSE'
                                                      },
                                           'CommuneNaissance' => 'PARIS',
                                           'TypeDeces' => 'N',
                                           'NumeroReponse' => '1',
                                           'CodeLieuNaissance' => '75000',
                                           'Nom' => 'DUPONT'
                                         }
                            },
                'NumeroQuestion' => '1'
              },
              {
                'NombreReponses' => '2',
                'EtapeReponses' => '3',
                'Reponses' => {
                              'Reponse' => [
                                           {
                                             'CodeLieuDeces' => '76000',
                                             'NumeroActeDeces' => '0007765',
                                             'DateNaissance' => {
                                                                'JourNaissance' => '18',
                                                                'MoisNaissance' => '1',
                                                                'AnneeNaissance' =>'1903'
                                                              },
                                             'Sexe' => 'F',
                                             'DateDeces' => {
                                                            'MoisDeces' => '01',
                                                            'AnneeDeces' => '2008',
                                                            'JourDeces' => '02'
                                                          },
                                             'Prenoms' => {
                                                          'Prenom1' => 'MARYSE'
                                                        },
                                             'CommuneNaissance' => 'TOURS',
                                             'TypeDeces' => 'A',
                                             'NumeroReponse' => '1',
                                             'CodeLieuNaissance' => '37015',
                                             'Nom' => 'DE DURAND'
                                           },
                                           {
                                             'CodeLieuDeces' => '61014',
                                             'NumeroActeDeces' => 'ALENCON',
                                             'DateNaissance' => {
                                                                'JourNaissance' => '25',
                                                                'MoisNaissance' => '08',
                                                                'AnneeNaissance' =>'1903'
                                                              },
                                             'Sexe' => 'F',
                                             'DateDeces' => {
                                                            'MoisDeces' => '06',
                                                            'AnneeDeces' => '1999',
                                                            'JourDeces' => '06'
                                                          },
                                             'Prenoms' => {
                                                          'Prenom2' => 'JOCELYNE',
                                                          'Prenom1' => 'MARYSE'
                                                        },
                                             'CommuneNaissance' => 'TOURS',
                                             'TypeDeces' => 'N',
                                             'NumeroReponse' => '2',
                                             'CodeLieuNaissance' => '37016',
                                             'Nom' => 'DE DURAND'
                                           }
                                         ]
                            },
                'NumeroQuestion' => '2'
              }
            ];
    Je n'arrive pas à interpréter le résultat, je voudrai faire "sauter" les '[]' et boucler (avec un for ou une méthode prédéfinie via XML::Simple) sur les '{}'...

    Merci d'avance.

  2. #2
    Responsable Perl et Outils

    Avatar de djibril
    Homme Profil pro
    Inscrit en
    Avril 2004
    Messages
    19 820
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 19 820
    Points : 498 771
    Points
    498 771
    Par défaut
    T'as pas du lire la bonne . T'as regarder les tutoriels de notre rubrique Perl ?

  3. #3
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    42
    Détails du profil
    Informations personnelles :
    Localisation : France, Sarthe (Pays de la Loire)

    Informations forums :
    Inscription : Avril 2006
    Messages : 42
    Points : 39
    Points
    39
    Par défaut
    Je pensais, mais apparement j'ai pas correctement parcouru les tuto,

    As tu un lien pour me venir en aide....

  4. #4
    Responsable Perl et Outils

    Avatar de djibril
    Homme Profil pro
    Inscrit en
    Avril 2004
    Messages
    19 820
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 19 820
    Points : 498 771
    Points
    498 771
    Par défaut
    ici.

    Regarde la documentation sur les XML.

  5. #5
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    42
    Détails du profil
    Informations personnelles :
    Localisation : France, Sarthe (Pays de la Loire)

    Informations forums :
    Inscription : Avril 2006
    Messages : 42
    Points : 39
    Points
    39
    Par défaut
    En effet, je n'ai pas vu ce tuto, je pense qu'il peut m'aider......

    Merci bcp

  6. #6
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Décembre 2009
    Messages
    25
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2009
    Messages : 25
    Points : 32
    Points
    32
    Par défaut
    Bonjour,
    vous pouvez essayer ça
    avec la librairie XML:OM
    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
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
     
    #!/usr/bin/perl 
     
    use strict;
    use warnings;
    use XML::DOM;
     
    my $pathFileXML="/tmp/text.xml";
    my $strCSV="";
    my $parser = new XML::DOM::Parser;
    my $doc = $parser->parsefile ($pathFileXML);
    my @tabListObj=('CodeLieuDeces', 'NumeroActeDeces', 'DateNaissance', 'Sexe', 'DateDeces', 'Prenoms', 'CommuneNaissance', 'TypeDeces', 'NumeroReponse', 'CodeLieuNaissance', 'Nom');
    my $tabListObjLength=$#tabListObj;
    #root est le nom de la balise root du document XML
    #a remplacer par la votre 
    my $nodeFiles = $doc->getElementsByTagName("root");
    for my $childFiles ($nodeFiles->getChildNodes){
    	my $nodeFile = $childFiles;
    	for(my $i=0; $i<$tabListObjLength; $i++){
    		my $titreBalise=$tabListObj[$i];
    		if($titreBalise=~/^Date/){
    			for my $childDates ($childFiles->getAttributeNode ($titreBalise)->item(0)->getChildNodes){
    				my $tagNameDate=$childDates->getNodeName();
    				$strCSV.=$titreBalise.";".$tagNameDate.";"$childDates->item(0)->getFirstChild()->getNodeValue();
    				$strCSV.="\n";
    			}
    		}
    		elsif($titreBalise=~/^Prenoms/){
    			for my $childDates ($childFiles->getAttributeNode ($titreBalise)->item(0)->getChildNodes){
    				my $tagNameDate=$childDates->getNodeName();
    				$strCSV.=$titreBalise.";".$tagNameDate.";"$childDates->item(0)->getFirstChild()->getNodeValue();
    				$strCSV.="\n";
    			}
    		}else{
    			$strCSV.=$titreBalise.";".$childFiles->getAttributeNode ($titreBalise)->item(0)->getFirstChild()->getNodeValue();
    			$strCSV.="\n";
    		}
    	}
    }
    open FICCSV ">/tmp/testCSV.csv";
    print FICCSV $strCSV;
    close FICCSV;
    __END__
    --
    http://vgt.fr

  7. #7
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    42
    Détails du profil
    Informations personnelles :
    Localisation : France, Sarthe (Pays de la Loire)

    Informations forums :
    Inscription : Avril 2006
    Messages : 42
    Points : 39
    Points
    39
    Par défaut
    Merci pour votre aide. Ca marche nickel... Enfin jusqu'au prochain bug

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

Discussions similaires

  1. [XSLT 1.0] Conversion xml vers xml
    Par henri93 dans le forum XSL/XSLT/XPATH
    Réponses: 2
    Dernier message: 01/04/2011, 07h21
  2. [XSLT 1.0] Conversion XML vers XML: non affichage de valeur
    Par f.thevenet dans le forum XSL/XSLT/XPATH
    Réponses: 4
    Dernier message: 03/03/2011, 10h15
  3. [XML] Conversion XML => MDB
    Par pc75 dans le forum XSL/XSLT/XPATH
    Réponses: 2
    Dernier message: 28/11/2006, 08h39
  4. [XML] conversion xml en mysql
    Par php_de_travers dans le forum XQUERY/SGBD
    Réponses: 3
    Dernier message: 18/10/2006, 07h46
  5. [xml]Conversion d'une structure xml en csv
    Par cchatel2000 dans le forum XML/XSL et SOAP
    Réponses: 3
    Dernier message: 01/08/2005, 16h00

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