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 :

Ecriture dans un csv à partir d'un autre csv


Sujet :

Python

  1. #1
    Membre averti
    Homme Profil pro
    Consultant MOA
    Inscrit en
    Mars 2017
    Messages
    12
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Charente Maritime (Poitou Charente)

    Informations professionnelles :
    Activité : Consultant MOA
    Secteur : Conseil

    Informations forums :
    Inscription : Mars 2017
    Messages : 12
    Par défaut Ecriture dans un csv à partir d'un autre csv
    Bonjour,

    je suis un exercice python qui consiste à récupérer les données présentes dans un csv puis à modifier ces données pour les écrire dans un autre fichier csv.
    J'avoue je sèche complement sur l'écriture du nouveau fichier.

    **notez que dans un premier temps je voulais prendre les données de input.csv pour les ecrire dans output.csv

    Actuellement j'arrive à récup les données de input.csv sous la forme d'un dictionnaire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    import csv
     
    with open('input.csv') as fichier_csv:
        reader = csv.DictReader(fichier_csv,delimiter=',')
        for ligne in reader:
            print(ligne)
    resultat :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
     
    Python - main.py:7
    {'noms': 'Pierre Durand', 'h_ts': '36'}
    {'noms': 'Paul Dupont', 'h_ts': '41'}
    {'noms': 'Edouard Gentil', 'h_ts': '40'}
    Ensuite je créé le fichier output.csv et j'écris dedans :


    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
    import csv
     
    with open('input.csv') as fichier_csv:
        reader = csv.DictReader(fichier_csv,delimiter=',')
        for ligne in reader:
            print(ligne)
    en_tete = ["noms", "h_ts"]
    with open('output.csv', 'w') as fichier_csv:
           # Créer un objet writer (écriture) avec ce fichier
            writer = csv.writer(fichier_csv, delimiter=',')
            writer.writerow(en_tete)
           # Parcourir les titres et descriptions - zip permet d'itérer sur deux listes ou plus à la fois
    for nom, h_t in zip(noms, h_ts):
              # Créer une nouvelle ligne avec le titre et la description à ce moment de la boucle
              ligne = [nom, h_t]
              writer.writerow(ligne)
    c'est que j'ai une erreur :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     line 13, in <module>
        for nom, h_t in zip(noms, h_ts):
    NameError: name 'noms' is not defined
    [Finished in 0.131s]
    noms et h_ts ne sont pas définis

  2. #2
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 741
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 741
    Par défaut
    Salut,

    L'erreur dit que la variable noms n'est pas définie.

    En Python, une variable est définie lorsqu'on lui a assigné quelque chose (l'instruction noms = ...)

    Peut être que vous devriez apprendre les bases avant de vouloir vous lancer dans quelque chose qui paraît simple (mais c'est devant le mur qu'on voit le maçon).

    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  3. #3
    Membre Expert
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Février 2003
    Messages
    1 603
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Industrie

    Informations forums :
    Inscription : Février 2003
    Messages : 1 603
    Par défaut
    J'ajoute que, puisque tu utilises csv.DictReader pour lire en entrée le csv, tu pourrais utiliser en sortie csv.DictWriter

    https://docs.python.org/fr/3.6/libra...csv.DictWriter

  4. #4
    Invité
    Invité(e)
    Par défaut
    Citation Envoyé par wiztricks Voir le message
    mais c'est devant le mur qu'on voit le maçon).
    Chui collé au mur, je le vois toujours pas (le maçon), j'ai fait une erreur à quel moment ?
    Peut-être pas sur le bon forum, moi...

Discussions similaires

  1. Réponses: 2
    Dernier message: 31/01/2008, 17h58
  2. Nombre aléatoire dans un intervalle (à partir d'un autre compris [0,1) )
    Par zoonel dans le forum Algorithmes et structures de données
    Réponses: 10
    Dernier message: 16/01/2008, 14h00
  3. Réponses: 1
    Dernier message: 21/11/2007, 21h53
  4. Réponses: 4
    Dernier message: 03/06/2006, 12h45
  5. Ajouter du texte dans un input à partir d'une autre fenêtre
    Par Michaël dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 13/04/2005, 20h14

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