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 :

String to List


Sujet :

Python

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Février 2010
    Messages
    571
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2010
    Messages : 571
    Points : 97
    Points
    97
    Par défaut String to List
    Bonjour,

    Dans un de mes fichiers csv, j'ai une colonne qui contient une string sous le format suivant:
    ['text1', 'text2']

    A la vue, ca ressemble à une liste mais en fait c'est une str
    Une solution est de remplacer les caractères []' par vide et de spliter sur la virgule

    Mais existe t'il une solution plus élégante ??

    Thais

  2. #2
    Expert éminent sénior
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 287
    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 287
    Points : 36 776
    Points
    36 776
    Par défaut
    Citation Envoyé par thais781 Voir le message
    Mais existe t'il une solution plus élégante ??
    Déjà, il n'est pas normal de trouver des chaines de caractères de la forme ['text1', 'text2'] dans une colonne: on devrait avoir 2 colonnes.
    > Peut être faut-il revoir comment est généré le CSV?
    Sinon, eval ou mieux ast.literal_eval et un .join sur la liste récupérée devraient le faire.

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

  3. #3
    Membre chevronné
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Février 2003
    Messages
    1 572
    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 572
    Points : 2 014
    Points
    2 014
    Par défaut
    Bonjour,

    quelque chose comme ça peut faire le job :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ma_chaine = ma_chaine[1:-1].replace("'","").split(', ')
    Mais c'est effectivement peu commun de récupérer le contenu d'une liste dans une string.

  4. #4
    Expert éminent sénior
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 690
    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 690
    Points : 30 984
    Points
    30 984
    Billets dans le blog
    1
    Par défaut
    Bonjour
    Citation Envoyé par thais781 Voir le message
    A la vue, ca ressemble à une liste mais en fait c'est une str
    En fait, ça ressemble à une liste qui aurait été écrite dans le csv sous forme str. Ce qui pourrait relever d'une erreur en amont. Il serait peut-être utile d'investiguer à propos de cette erreur potentielle pour voir s'il s'agit vraiment d'une erreur et d'essayer de la corriger plutôt que de vouloir rattrapper le coup après coup. Peut-être qu'à l'origine, "text1" était destiné à aller dans une colonne X du csv et "text2" dans la colonne "X+1". Que se passera-t-il si un jour text1 contient une apostrophe?
    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]

  5. #5
    Membre régulier
    Profil pro
    Inscrit en
    Février 2010
    Messages
    571
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2010
    Messages : 571
    Points : 97
    Points
    97
    Par défaut
    Top, merci pour votre aide.
    Effectivment ast.literal_eval fonctionne très bien.

    En fait, il y dans cette colonne des liste dont la dimension est variable
    Je ne sais pas comment il aurait pu la stocker.
    Perso, j'aurai fais un autre fichier csv avec cette colonne et une clé de liaison avec le premier csv ... mais bon, je dois faire avec ;-)

    Merci encore

    Thais

  6. #6
    Membre chevronné
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Février 2003
    Messages
    1 572
    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 572
    Points : 2 014
    Points
    2 014
    Par défaut
    Citation Envoyé par thais781 Voir le message
    TEn fait, il y dans cette colonne des liste dont la dimension est variable
    Je ne sais pas comment il aurait pu la stocker.
    Perso, j'aurai fais un autre fichier csv avec cette colonne et une clé de liaison avec le premier csv ... mais bon, je dois faire avec ;-)
    Ou bien un fichier JSON.

  7. #7
    Expert éminent sénior
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 690
    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 690
    Points : 30 984
    Points
    30 984
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par thais781 Voir le message
    Je ne sais pas comment il aurait pu la stocker.
    On peut dire par exemple "toutes les colonnes à partir de telle colonne C, et terminées par une colonne spéciale _EOT_". La liaison avec un second CSV est aussi une idée (qui ressemble aux clefs étrangères dans une bdd) mais plus compliqué à maintenir.
    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]

  8. #8
    Expert confirmé
    Avatar de popo
    Homme Profil pro
    Analyste programmeur Delphi / C#
    Inscrit en
    Mars 2005
    Messages
    2 674
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Analyste programmeur Delphi / C#
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2005
    Messages : 2 674
    Points : 5 259
    Points
    5 259
    Par défaut
    Un CSV est fait pour présenter des données tabulaires ayant toutes la même structure.
    Là tu des données en relation 1..n avec d'autres données, donc le format CSV n'est plus adapté.

    Comme la suggéré Arioch, JSON est plus adapté à ta structure.

Discussions similaires

  1. Conversion string to liste
    Par midos dans le forum Prolog
    Réponses: 3
    Dernier message: 21/02/2010, 09h47
  2. Convert String to List
    Par hibernatefun dans le forum Langage
    Réponses: 6
    Dernier message: 16/02/2010, 18h05
  3. Requête : transformer string en liste
    Par DrizztDo dans le forum Requêtes et SQL.
    Réponses: 6
    Dernier message: 05/02/2009, 14h43
  4. Réponses: 15
    Dernier message: 30/09/2008, 14h43
  5. Réponses: 4
    Dernier message: 03/05/2006, 14h30

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