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 :

Convertir fichier *.txt en fichier *.csv [Python 3.X]


Sujet :

Python

  1. #1
    Membre éclairé
    Homme Profil pro
    Touche à tout
    Inscrit en
    Mai 2017
    Messages
    474
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Allier (Auvergne)

    Informations professionnelles :
    Activité : Touche à tout

    Informations forums :
    Inscription : Mai 2017
    Messages : 474
    Par défaut Convertir fichier *.txt en fichier *.csv
    Bonjour,

    Je souhaiterai lire un fichier *.txt avec comme séparateur '|' pour le stocker dans un fichier *.csv avec bien sûr une cellule par chaque éléments séparés par '|'.

    Merci par avance pour votre aide.

  2. #2
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 814
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 814
    Billets dans le blog
    1
    Par défaut
    Bonjour
    Citation Envoyé par Supernatural Voir le message
    Je souhaiterai lire un fichier *.txt avec comme séparateur '|' pour le stocker dans un fichier *.csv avec bien sûr une cellule par chaque éléments séparés par '|'.
    shutil.copyfile('fichier.txt', 'fichier.csv')...
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  3. #3
    Membre éclairé
    Homme Profil pro
    Touche à tout
    Inscrit en
    Mai 2017
    Messages
    474
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Allier (Auvergne)

    Informations professionnelles :
    Activité : Touche à tout

    Informations forums :
    Inscription : Mai 2017
    Messages : 474
    Par défaut
    Oui j'ai déjà utilisé une fonction similaire, mais le problème est que chaque ligne est copiée dans une seule cellule. Je voudrais que (par exemple):
    Contenu de mon fichier txt:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    |0256985214|toto est parti à l'ecole|pas de cantine ce midi|2.30€|
    Et que chaque élément séparé de '|' soit chacun dans une cellule respective.

    Merci.

  4. #4
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 695
    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 695
    Par défaut
    Citation Envoyé par Supernatural Voir le message
    Oui j'ai déjà utilisé une fonction similaire, mais le problème est que chaque ligne est copiée dans une seule cellule.
    Ce qui fait la cellule est la façon de découper la ligne suivant le delimiteur "|"...
    Donc s'il y a problème, il n'est pas dans le contenu du fichier mais dans ce que vous en faites.

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

  5. #5
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 814
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 814
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par Supernatural Voir le message
    Je voudrais que (par exemple)... et que chaque élément séparé de '|' soit chacun dans une cellule respective.
    Il n'y a pas de notion de "cellule" en csv. Un csv ce n'est qu'un txt, ni plus, ni moins. Enfi si, il y a du "moins". Le "moins" c'est qu'un txt c'est du vrac sans contrainte tandis que le csv doit avoir toutes ses lignes structurées de la même façon. Mais mis à part ce détail, un csv ça reste du bête fichier texte.
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  6. #6
    Membre éclairé
    Homme Profil pro
    Touche à tout
    Inscrit en
    Mai 2017
    Messages
    474
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Allier (Auvergne)

    Informations professionnelles :
    Activité : Touche à tout

    Informations forums :
    Inscription : Mai 2017
    Messages : 474
    Par défaut
    J'ai trouvé un bout de solution ^^
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    with open(TXT_Filename) as infile, open(CSV_Filename,'w') as outfile: 
        for line in infile: 
            outfile.write(line.replace('|',';'))

  7. #7
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 695
    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 695
    Par défaut
    Citation Envoyé par Supernatural Voir le message
    J'ai trouvé un bout de solution ^^

    Avant de chercher une solution, il faudrait comprendre le problème.

    Un fichier peut être CSV avec n'importe quel délimiteur ";", "|", " ",.... (et ce malgré le C)
    Il suffit de le dire au module csv lors de l'open en précisant lequel via delimiter='...'

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

  8. #8
    Membre Expert
    Homme Profil pro
    Enseignant
    Inscrit en
    Juin 2013
    Messages
    1 617
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Enseignant
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2013
    Messages : 1 617
    Par défaut
    En fait, le plus simple serait peut-être d'ouvrir le fichier .txt à l'aide de libbroffice par exemple, avec le séparateur voulu, et de l'enregistrer en .csv avec le séparateur voulu ?

  9. #9
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 695
    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 695
    Par défaut
    Citation Envoyé par marco056 Voir le message
    En fait, le plus simple serait peut-être d'ouvrir le fichier .txt à l'aide de libbroffice par exemple, avec le séparateur voulu, et de l'enregistrer en .csv avec le séparateur voulu ?
    Si tu le dis...

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

  10. #10
    Membre Expert
    Homme Profil pro
    Enseignant
    Inscrit en
    Juin 2013
    Messages
    1 617
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Enseignant
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2013
    Messages : 1 617
    Par défaut
    Citation Envoyé par wiztricks Voir le message
    Si tu le dis...

    - W
    S'il n'y a qu'un seul fichier à traiter, je ne vois pas l'intérêt de faire un programme pour le convertir d'un format à l'autre.
    Ce n'est que mon avis bien sûr.
    S'il y a plusieurs fichiers .txt ou qu'il faut le faire plusieurs fois, c'est différent...

  11. #11
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 695
    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 695
    Par défaut
    Citation Envoyé par marco056 Voir le message
    S'il n'y a qu'un seul fichier à traiter, je ne vois pas l'intérêt de faire un programme pour le convertir d'un format à l'autre.
    Il n'y a aucun fichier à traiter puisqu'on peut s’accommoder du délimiteur '|' (même avec libre office).

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

  12. #12
    Membre Expert
    Homme Profil pro
    Enseignant
    Inscrit en
    Juin 2013
    Messages
    1 617
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Enseignant
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2013
    Messages : 1 617
    Par défaut
    Citation Envoyé par wiztricks Voir le message
    Il n'y a aucun fichier à traiter puisqu'on peut s’accommoder du délimiteur '|' (même avec libre office).

    - W
    Ce n'est pas ce que je comprends en lisant le premier post.

  13. #13
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 814
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 814
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par Supernatural Voir le message
    J'ai trouvé un bout de solution ^^
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    with open(TXT_Filename) as infile, open(CSV_Filename,'w') as outfile: 
        for line in infile: 
            outfile.write(line.replace('|',';'))
    Super. Tu recopies ton txt dans ton csv en remplaçant les "|" par des ";". Si ça te convient... En tout cas il n'y a aucune notion de "cellule".

    Citation Envoyé par marco056 Voir le message
    S'il n'y a qu'un seul fichier à traiter, je ne vois pas l'intérêt de faire un programme pour le convertir d'un format à l'autre.
    Ce n'est que mon avis bien sûr.
    D'autant plus que le csv ce n'est pas un format différent d'un txt, c'est le même !!! Il n'y a donc même pas à parler de "un format à un autre".
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  14. #14
    Membre Expert
    Homme Profil pro
    Enseignant
    Inscrit en
    Juin 2013
    Messages
    1 617
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Enseignant
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2013
    Messages : 1 617
    Par défaut
    Citation Envoyé par Sve@r Voir le message
    Super. Tu recopies ton txt dans ton csv en remplaçant les "|" par des ";". Si ça te convient... En tout cas il n'y a aucune notion de "cellule".


    D'autant plus que le csv ce n'est pas un format différent d'un txt, c'est le même !!! Il n'y a donc même pas à parler de "un format à un autre".
    Oui, c'est l'extension qui change.

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

Discussions similaires

  1. [Batch] Convertir fichier csv unix en dos
    Par faulk dans le forum Scripts/Batch
    Réponses: 0
    Dernier message: 21/07/2010, 10h51
  2. Convertir fichier csv
    Par harlockbaz dans le forum VBA Access
    Réponses: 6
    Dernier message: 17/01/2008, 11h22
  3. [XML] convertir fichier CSV en XML
    Par Yudala dans le forum XML/XSL et SOAP
    Réponses: 1
    Dernier message: 16/02/2007, 10h05

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