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

Python Discussion :

Fichier XML avec plusieurs balises identiques [Python 3.X]


Sujet :

Python

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre régulier
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2020
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2020
    Messages : 7
    Par défaut Fichier XML avec plusieurs balises identiques
    Bonjour,

    Je dispose d'un fichier de plusieurs milliers de lignes dont chacune d'elles est composé de données XML.
    Ex d'une ligne: donnée 1, donnée 2, donnée 3,
    Code XML : Sélectionner tout - Visualiser dans une fenêtre à part
    <?xml version="1.0" encoding="UTF-8"?><root>données</root>

    Tout d'abord j'aurais souhaité avoir la confirmation que xml.etree.ElementTree ne peut prendre en charge que des fichiers et que je ne peux pas l'utiliser avec l'indice de la liste ou une variable afin d'éviter la création d'un fichier. J'ai essayé mais sans résultat mais peut être qu'il y a une méthode que je ne connais pas.

    Mon autre difficulté est que mon fichier XML a plusieurs balises identiques

    Code XML : 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
    <?xml version="1.0" encoding="UTF-8"?>
    <root>
      <data>
        <pays>France</pays>
        <langue>Français</langue>
        <monnaie>Euro</monnaie>
      </data>
      <data>
        <pays>Allemagne</pays>
        <langue>Allemand</langue>
        <monnaie>Euro</monnaie>
      </data>
      <data>
        <pays>Italie</pays>
        <langue>Italien</langue>
        <monnaie>Euro</monnaie>
      </data>
      <data>
        <pays>Espagne</pays>
        <langue>Espagnol</langue>
        <monnaie>Euro</monnaie>
      </data>
    </root>



    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    import xml.etree.ElementTree as ET                                                                                    
    root = ET.parse("Paystest.xml").getroot()                                    
     
    for item in root.iter("pays"):
        pays = item.text
        print(pays)
     
    for lang in root.iter("langue"):         
        langue = lang.text
        print(langue)
     
    for monn in root.iter("monnaie"):
        monnaie = monn.text
        print(monnaie)

    A la sortie j'ai ça comme résultat:

    France
    Allemagne
    Italie
    Espagne
    Français
    Allemand
    Italien
    Espagnol
    Euro
    Euro
    Euro
    Euro

    Je souhaiterais avoir les données regroupées par bloc:

    France
    Français
    Euro
    Allemagne
    Allemand
    Euro
    Italie
    Italien
    Euro
    Espagne
    Espagnol
    Euro
    Je voudrais savoir si c'est possible d'arriver à ce résultat.

    Merci

  2. #2
    Rédacteur

    Avatar de danielhagnoul
    Homme Profil pro
    Étudiant perpétuel
    Inscrit en
    Février 2009
    Messages
    6 389
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 74
    Localisation : Belgique

    Informations professionnelles :
    Activité : Étudiant perpétuel
    Secteur : Enseignement

    Informations forums :
    Inscription : Février 2009
    Messages : 6 389
    Billets dans le blog
    125
    Par défaut


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    for data in root.iter('data'):
        print('-' * 10, ' ' + data.findtext('pays') + ' ', '-' * 10)
        print(data.findtext('langue'))
        print(data.findtext('monnaie'))

    EDIT : meilleur code pour la présentation du nom du pays :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    for data in root.iter('data'):
        print("{:-^20s}".format(' ' + data.findtext('pays') + ' '))
        print(data.findtext('langue'))
        print(data.findtext('monnaie'))
    ------ France ------
    Français
    Euro
    ---- Allemagne -----
    Allemand
    Euro
    ------ Italie ------
    Italien
    Euro
    ----- Espagne ------
    Espagnol
    Euro

    Blog

    Sans l'analyse et la conception, la programmation est l'art d'ajouter des bogues à un fichier texte vide.
    (Louis Srygley : Without requirements or design, programming is the art of adding bugs to an empty text file.)

  3. #3
    Membre régulier
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2020
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2020
    Messages : 7
    Par défaut
    merci beaucoup.

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

Discussions similaires

  1. [XL-2007] Extraire des données d'un fichier Xml avec des balises identiques
    Par Danieldu54 dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 08/03/2011, 20h45
  2. fichiers XML avec des balises auto-fermantes
    Par processeur dans le forum Général Python
    Réponses: 0
    Dernier message: 15/08/2009, 19h14
  3. Réponses: 3
    Dernier message: 24/07/2009, 14h04
  4. Réponses: 2
    Dernier message: 27/03/2009, 17h44
  5. Réponses: 4
    Dernier message: 10/10/2007, 11h11

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