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 :

Insérer dans un CSV sans delimiter


Sujet :

Python

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti Avatar de Basiqueur
    Homme Profil pro
    Auditeur informatique
    Inscrit en
    Janvier 2022
    Messages
    16
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 65
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Auditeur informatique

    Informations forums :
    Inscription : Janvier 2022
    Messages : 16
    Par défaut Insérer dans un CSV sans delimiter
    Bonjour tout le monde,

    J'ajoute des chaînes de caractères ligne après ligne dans un fichier CSV avec la routine suivante :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    with open ('Liste triplettes.csv','w') as csvfile:
        NewCSV = csv.writer(csvfile)
        NewCSV.writerow("AAA/BBB ZZZ/YYY CCC/DDD")
        NewCSV.writerow("AAA/CCC TTT/YYY CCC/EEE")
        NewCSV.writerow("YYY/CCC TTT/VVV CCC/EEE")
    Cela fonctionne correctement sauf qu'une fois que j'ouvre le CSV, je me rends compte que Python rajoute une virgule comme Delimiter entre chaque caractère ce qui donne :
    A,A,A,/,B,B,B, ,Z,Z,Z,/,Y,Y,Y, ,C,C,C,/,D,D,D
    A,A,A,/,C,C,C, ,T,T,T,/,Y,Y,Y, ,C,C,C,/,E,E,E
    Y,Y,Y,/,C,C,C, ,T,T,T,/,V,V,V, ,C,C,C,/,E,E,E
    Comment éviter l'ajout de cette maudite virgule ?

    Je vous remercie par avance de votre aide

  2. #2
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 762
    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 762
    Par défaut
    Salut,

    Citation Envoyé par Basiqueur Voir le message
    Comment éviter l'ajout de cette maudite virgule ?
    Pour écrire des lignes dans un fichier inutile d'utiliser le module CSV, autant le faire directement.
    Et si vous voulez utiliser le module CSV, ouvrir la documentation pour voir comment fonctionne .writerow n'est pas du luxe...

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

  3. #3
    Membre averti Avatar de Basiqueur
    Homme Profil pro
    Auditeur informatique
    Inscrit en
    Janvier 2022
    Messages
    16
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 65
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Auditeur informatique

    Informations forums :
    Inscription : Janvier 2022
    Messages : 16
    Par défaut
    Bonsoir et merci pour ta réponse,

    Citation Envoyé par wiztricks Voir le message
    Pour écrire des lignes dans un fichier inutile d'utiliser le module CSV, autant le faire directement.
    Utiliser le module CSV pour lire et écrire un CSV ça paraissait pourtant être une bonne solution. Mais je suis preneur de toute idée plus direct si tu en as une.

    Citation Envoyé par wiztricks Voir le message
    Et si vous voulez utiliser le module CSV, ouvrir la documentation pour voir comment fonctionne .writerow n'est pas du luxe...
    Si je pose la question ici, c'est que j'ai déjà cherché un bon moment. Le paramètre Delimiter de Writerow nécessite forcément un caractère et par défaut il insère une virgule. Je débute en Python depuis quelques jours et je ne suis même pas sûr que mon soucis vienne de Writerow.[/QUOTE]

  4. #4
    Membre Expert
    Homme Profil pro
    Inscrit en
    Octobre 2011
    Messages
    2 910
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Octobre 2011
    Messages : 2 910
    Par défaut
    Citation Envoyé par Basiqueur Voir le message
    Mais je suis preneur de toute idée plus direct si tu en as une.
    Une façon "direct" (sans module csv) serait par exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    with open('Liste triplettes.csv', 'w') as file:    
        file.write("AAA/BBB ZZZ/YYY CCC/DDD\n")
        file.write("AAA/CCC TTT/YYY CCC/EEE\n")
        file.write("YYY/CCC TTT/VVV CCC/EEE\n")

  5. #5
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 762
    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 762
    Par défaut
    Citation Envoyé par Basiqueur Voir le message
    Je débute en Python depuis quelques jours et je ne suis même pas sûr que mon soucis vienne de Writerow.
    Débuter avec Python, c'est trouver un bon tuto. et y passer du temps.
    Tous les bons tutos ont un chapitre qui traite des fichiers avec Python (car il y a des choses à savoir...).
    Et vous êtes supposé avoir passé du temps dans un bon tuto avant de venir demander de l'aide ici (voir les règles avant de poster).

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

  6. #6
    Membre Expert
    Profil pro
    Inscrit en
    Septembre 2010
    Messages
    1 547
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France

    Informations forums :
    Inscription : Septembre 2010
    Messages : 1 547
    Par défaut
    Dans ton cas, on pourrais dire que le délimiter c'est un espace et dans ce cas:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    with open ('Liste triplettes.csv','w',newline='') as csvfile:
        NewCSV = csv.writer(csvfile,delimiter=' ')
        NewCSV.writerow(["AAA/BBB", "ZZZ/YYY", "CCC/DDD"])
        NewCSV.writerow(["AAA/CCC", "TTT/YYY", "CCC/EEE"])
        NewCSV.writerow(["YYY/CCC", "TTT/VVV", "CCC/EEE"])
    Mais bon, dans ce cas précis,on peut aussi l'écrire sans le module csv comme dit plus haut

  7. #7
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 840
    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 840
    Billets dans le blog
    1
    Par défaut
    Bonjour
    Citation Envoyé par Basiqueur Voir le message
    Utiliser le module CSV pour lire et écrire un CSV ça paraissait pourtant être une bonne solution.
    Oui, c'est une excellente solution quand tu dois lire et écrire un vrai CSV. Mais un fichier qui n'a pas de caractère de séparation ce n'est pas un CSV (va relire la définition du sigle "C.S.V.") ; c'est un simple texte.
    Ou alors comme le dit umfred tu décides que l'espace sera le caractère de séparation mais dans ce cas, plus d'espace dans tes chaines (ou alors chaines encadrées de guillemets).

    Citation Envoyé par Basiqueur Voir le message
    Le paramètre Delimiter de Writerow nécessite forcément un caractère et par défaut il insère une virgule
    Oui par défaut. Mais rien ne t'interdit de mettre ce que tu veux.
    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]

Discussions similaires

  1. Réponses: 16
    Dernier message: 11/11/2018, 18h28
  2. Rajouter des lignes dans un csv sans l'écraser
    Par JulienNvr dans le forum VBA Outlook
    Réponses: 2
    Dernier message: 03/07/2013, 10h08
  3. Réponses: 7
    Dernier message: 08/06/2012, 16h24
  4. Réponses: 4
    Dernier message: 07/07/2011, 11h17
  5. Réponses: 4
    Dernier message: 18/10/2007, 22h10

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