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 :

remplacer une ligne dans un fichier csv


Sujet :

Python

  1. #1
    Membre habitué
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2020
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 24
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2020
    Messages : 7
    Par défaut remplacer une ligne dans un fichier csv
    Bonjour
    J'ai un fichier csv avec plusieurs lignes et je souhaiterais en remplacer une par une autre
    Sachant que par exemple je souhaite remplacer la 2eme ligne de mon fichier comment dois-je faire?
    SVP
    Merci d'avance

  2. #2
    Expert confirmé
    Avatar de tyrtamos
    Homme Profil pro
    Retraité
    Inscrit en
    Décembre 2007
    Messages
    4 486
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2007
    Messages : 4 486
    Billets dans le blog
    6
    Par défaut
    Bonjour,

    Si c'est pour faire ça une seule fois, le plus simple est d'utiliser... un éditeur de texte.

    Si c'est pour faire ça dans le cadre d'un programme, il n'y a pas d'autre solution que de lire de fichier, et de l'écrire sur disque après avoir appliqué les modifications voulues. En effet, comme les lignes n'ont pas une longueur identique en octets, on ne peut pas modifier une ligne en particulier en y accédant directement.

    Principe du code (adapter si nécessaire l'encodage du fichier):

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    lignes = []
    with open("monfichier.csv", "r", encoding="utf-8") as fs:
        for ligne in fs:
            lignes.append(ligne.rstrip()) # rstrip supprime la fin de ligne
    ...
    appliquer les modifs aux lignes de la liste "lignes"
    ...
    with open("monfichier_modif.csv", "w", encoding="utf-8") as fd:
        for ligne in lignes:
            fd.write(ligne + "\n")

  3. #3
    Membre habitué
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2020
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 24
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2020
    Messages : 7
    Par défaut
    D'accord donc on doit écraser le fichier
    Merci pour votre réponse

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

Discussions similaires

  1. Remplacer une ligne dans un fichier texte !
    Par toulouz1 dans le forum VBScript
    Réponses: 23
    Dernier message: 19/07/2017, 10h26
  2. [CSV] Effacer une ligne dans un fichier CSV
    Par poulepexo dans le forum Langage
    Réponses: 1
    Dernier message: 22/04/2009, 12h12
  3. Remplacer une ligne dans un fichier
    Par mister3957 dans le forum C++
    Réponses: 6
    Dernier message: 31/03/2009, 03h09
  4. Remplacer une ligne dans un fichier de configuration
    Par morgan47 dans le forum Langage
    Réponses: 3
    Dernier message: 08/09/2008, 13h15
  5. Remplacer une ligne dans un fichier ?
    Par FenX. dans le forum Shell et commandes GNU
    Réponses: 2
    Dernier message: 30/05/2008, 10h45

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