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 :

Création d'un fichier .xml récupérant des données d'un .csv


Sujet :

Python

  1. #1
    Membre habitué Avatar de iVault
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2018
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 26
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2018
    Messages : 8
    Par défaut Création d'un fichier .xml récupérant des données d'un .csv
    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
    import csv
    import xml.etree.cElementTree as ET
     
    name = raw_input("Entrez le nom d'une école : ")
     
    Ecole = {}  
     
    with open('ecoles.csv') as File:
        reader = csv.reader(File, delimiter=';')
     
        for row in reader:
            Ecole[name] = row[1:]
     
            if row[0] == name:
                print("Nom : {} |\nNomNetBios : {} |\nIP1 : {}|\nIP2 : {} |\nIP3 : {} |\nIP4 : {} |\nMAJ_Blacklist : {}".format(name, row[1], row[2], row[3], row[4], row[5], row[6], row[7]))
     
     
        prog = ET.Element("prog")
     
        NomEcole = ET.SubElement(prog, "NomEcole")
        ET.SubElement(NomEcole, "variable", name="NomEcole").text = row[0]
     
        NomNetBios = ET.SubElement(prog, "NomNetBios")
        ET.SubElement(NomNetBios, "variable", name="NomNetBios").text = row[1]
     
        AdressesIP = ET.SubElement(prog, "AdressesIP")
        ET.SubElement(AdressesIP, "variable", name="IP1").text = row[2]
     
        AdressesIP = ET.SubElement(prog, "AdressesIP")
        ET.SubElement(AdressesIP, "variable", name="IP2").text = row[3]
     
        AdressesIP = ET.SubElement(prog, "AdressesIP")
        ET.SubElement(AdressesIP, "variable", name="IP3").text = row[4]
     
        AdressesIP = ET.SubElement(prog, "AdressesIP")
        ET.SubElement(AdressesIP, "variable", name="IP4").text = row[5]
     
        MAJ_Blacklist = ET.SubElement(prog, "MAJ_Blacklist")
        ET.SubElement(MAJ_Blacklist, "variable", name="MAJ_Blacklist").text = row[6]
     
        tree = ET.ElementTree(prog)
        tree.write("ecole.xml", encoding="UTF-8")
    Donc dans ce code je récupère des données via l'insertion d'un nom d'un utilisateur, seulement dans le fichier xml qui est crée à la fin de ce code, les données à l'intérieur seront toujours les données de la dernière ligne de mon .csv, peu importe ce qu'insère l'utilisateur comme nom, je ne comprends pas d'où peut venir cette erreur et donc comment la fixer

    En revanche le print au dessus de la création du fichier .xml marche très bien.

    Deuxième problème avec ce code,

    le fichier xml ce génère en format UNIX et non Windows (oui je travaille sur Windows malheureusement durant mon stage )

  2. #2
    Expert confirmé Avatar de disedorgue
    Homme Profil pro
    Ingénieur intégration
    Inscrit en
    Décembre 2012
    Messages
    4 342
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur intégration
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Décembre 2012
    Messages : 4 342
    Par défaut
    Bonjour,

    Déjà, voyons le premier problème:
    Le print fonctionne bien car il est dans la boucle du bloc with open, par contre ton traitement de mise en forme en xml, lui est en dehors de la boucle, lorsque le fichier a été lu entièrement, ce qui explique que tu ne mets que la dernière ligne dans le xml.

    Pour le deuxième point, je ne comprends ton souci puisqu'en xml les retours de ligne ne font pas partie du format xml...

  3. #3
    Membre habitué Avatar de iVault
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2018
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 26
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2018
    Messages : 8
    Par défaut
    J'ai effectivement déjà tester l'indentation rien n'y fais le problème reste la, mais vous avez toute de même raison j'ai effectué la modification et édité mon post.
    En ce qui concerne le problème de format effectivement le problème est que le code xml s'affiche sur une seule ligne ce qui le rend illisible..
    des idées ? ...

  4. #4
    Expert confirmé Avatar de disedorgue
    Homme Profil pro
    Ingénieur intégration
    Inscrit en
    Décembre 2012
    Messages
    4 342
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur intégration
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Décembre 2012
    Messages : 4 342
    Par défaut
    Hmm...

    Si ton print te convient, pourquoi tu ne crées pas a ce moment là ton fichier ?
    Dit autrement, ton indentation n'est toujours pas bonne, elle se situe toujours à la fin de la lecture du fichier csv mais juste avant sa fermeture.

    Ton indentation doit se positionner au même niveau que ton print.

    Une amélioration serais aussi d'arrêter la boucle for et sortir du bloc with open dés l'instant ou tu as écris ton fichier xml. Il est inutile de conitnuer à lire ton fichier csv à partir du moment où tu as trouvé la ligne qui t'intéresse.

  5. #5
    Membre habitué Avatar de iVault
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2018
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 26
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2018
    Messages : 8
    Par défaut
    Merci beaucoup pour tes réponses qui m'ont beaucoup aidé!
    Moi qui commence Python, je ne savais pas qu'il fallait autant jouer avec l'indentation!

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

Discussions similaires

  1. Alimenter un fichier xml avec des données issues d'un fichier csv
    Par Sympa77 dans le forum XML/XSL et SOAP
    Réponses: 1
    Dernier message: 22/04/2017, 15h32
  2. [XML] Integrer des données d'un fichier xml dans un autre ?
    Par vpet dans le forum XML/XSL et SOAP
    Réponses: 2
    Dernier message: 16/03/2006, 18h41
  3. [XML] stocker des données dans un fichier XML
    Par R3iTt0R dans le forum XML/XSL et SOAP
    Réponses: 5
    Dernier message: 27/05/2005, 16h51

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