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 :

importer données de Ecxel vers Python


Sujet :

Python

  1. #1
    Membre du Club
    Inscrit en
    Avril 2008
    Messages
    7
    Détails du profil
    Informations forums :
    Inscription : Avril 2008
    Messages : 7
    Par défaut importer données de Ecxel vers Python
    salut les développeurs,
    j'ai besoin d'importer des données vers pyhton depuis un fichier Excel.
    je convertis mon fichier xls en csv en vue d'exploiter le module csv de python.

    import csv
    cr=csv.reader(open('path','rb'))

    le fichier est bien ouvert, je récupère les données mais pas sous forme de listes!!

    quand j'exécute la commande

    for row in cr:
    print row[0]

    toutes les données s'affichent
    mais je ne peus pas récupérer row[0][1] par exemple!
    ps: mes données sont toutes décimales, pas de dates, pas de chaines de caractères

    peut être que ça vous parait banal, mais je suis néophyte en python
    j'ai beau essayer! sans résultat
    j'aprécievotre aide

  2. #2
    Membre expérimenté Avatar de alexdevl
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    265
    Détails du profil
    Informations personnelles :
    Âge : 56
    Localisation : France, Loire (Rhône Alpes)

    Informations forums :
    Inscription : Avril 2007
    Messages : 265
    Par défaut
    Bonjour,
    Les ''csv'' sont des objets et ne sont pas accessibles comme une liste .

    Il faut avancer (itérer) dans l'objet pour créer une liste.
    Voici comment procéder.

    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
    17
    18
    19
    20
     
    # a) Version developpee
    path="classeur1.csv"
    import csv
    objetFichier=open(path,'rb')
    objetcsv=csv.reader(objetFichier,delimiter=';')
    print objetcsv
     
    lst=[]
    for row in objetcsv:
        lst.append(row)
     
    print lst
    print lst[0][1]
     
    # b) Version condensee
    print [row for row in csv.reader(open("classeur1.csv",'rb'),delimiter=';')][0][1]
     
    #c) version corrigee d'apres oiffrig
    print list(csv.reader(open("classeur1.csv",'rb'),delimiter=';'))  [0][1]

  3. #3
    Membre émérite

    Profil pro
    Inscrit en
    Août 2004
    Messages
    723
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2004
    Messages : 723
    Par défaut
    Petite amélioration:
    Pour obtenir une liste à partir d'un itérable (i.e. un objet qui supporte les boucles for), il suffit d'utiliser list (d'ailleurs, donner ce nom à une variable est déconseillé):
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    lst = list(objetcsv)
    #au lieu de
    lst=[]
    for row in objetcsv:
        lst.append(row)

  4. #4
    Membre expérimenté Avatar de alexdevl
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    265
    Détails du profil
    Informations personnelles :
    Âge : 56
    Localisation : France, Loire (Rhône Alpes)

    Informations forums :
    Inscription : Avril 2007
    Messages : 265
    Par défaut
    J'ai corrigé mon poste
    d'ailleurs, donner le nom ''list'' à une variable est déconseillé
    Oui je n'arrivais pas à utiliser list(..)

  5. #5
    Rédacteur/Modérateur

    Avatar de Jiyuu
    Homme Profil pro
    Développeur amateur
    Inscrit en
    Janvier 2007
    Messages
    2 456
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Loire (Rhône Alpes)

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

    Informations forums :
    Inscription : Janvier 2007
    Messages : 2 456
    Billets dans le blog
    15
    Par défaut
    Sinon encore plus simplement tu peux aller voir ça.

    Encore merci à Thierry (Chappuis) pour l'info qui m'a simplifiée la vie de manière incroyable...
    Initiation à Qt Quick et QML : Partie 1 - Partie 2
    En cas de besoin, pensez à la
    Mon site et mes tutoriaux sur Developpez.com
    Pas de question technique par MP... Les forums sont là pour ça

  6. #6
    Membre émérite
    Homme Profil pro
    Inscrit en
    Janvier 2006
    Messages
    491
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Corse (Corse)

    Informations forums :
    Inscription : Janvier 2006
    Messages : 491
    Par défaut
    bonjour, je rebondis sur ce sujet car je ne comprends pas car si je fais
    en reprenant l'exemple precedent row[0] j'ai la valeur de la ''colonne'' 1 ,row[1] ==>colonne 2... je n'ai pas besoin de transformé en liste

  7. #7
    Membre chevronné
    Homme Profil pro
    Inscrit en
    Mai 2002
    Messages
    309
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Meurthe et Moselle (Lorraine)

    Informations forums :
    Inscription : Mai 2002
    Messages : 309
    Par défaut
    C'est parce que dans le code ci-dessus, "row" est la variable indicée d'une boucle For et non une référence à une ligne de tableur. La dénomination de cette variable peu être tout a fait autre chose, car elle est incrémentée par les valeurs de la liste dans la suite des élément de cette liste. Rien a voir avec le format ou les références du tableur.

    Tu peux changer "row" en "donnee" c'est pareil.

  8. #8
    Membre émérite

    Profil pro
    Inscrit en
    Août 2004
    Messages
    723
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2004
    Messages : 723
    Par défaut
    Citation Envoyé par xavier-Pierre Voir le message
    bonjour, je rebondis sur ce sujet car je ne comprends pas car si je fais
    en reprenant l'exemple precedent row[0] j'ai la valeur de la ''colonne'' 1 ,row[1] ==>colonne 2... je n'ai pas besoin de transformé en liste
    Le problème de la liste ne concerne pas row, mais la variable lst, qui supporte l'itération mais pas l'accès à un élément, en clair c'est lst[0] par exemple qui ne marche pas.

    Citation Envoyé par Gamal le Celte Voir le message
    C'est parce que dans le code ci-dessus, "row" est la variable indicée d'une boucle For et non une référence à une ligne de tableur. La dénomination de cette variable peu être tout a fait autre chose, car elle est incrémentée par les valeurs de la liste dans la suite des élément de cette liste. Rien a voir avec le format ou les références du tableur.

    Tu peux changer "row" en "donnee" c'est pareil.
    Pas compris là Tu peux préciser ce que tu veux dire ?

  9. #9
    Membre émérite
    Homme Profil pro
    Inscrit en
    Janvier 2006
    Messages
    491
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Corse (Corse)

    Informations forums :
    Inscription : Janvier 2006
    Messages : 491
    Par défaut
    rebonjour ,je me suis mal exprimé
    j'ai un fichier a.csv
    si je fait le code
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    import csv
    f=open('c:\\a.csv')
    f_csv=csv.reader(f,delimiter=';')
    for l in f_csv:
        print l[0]
     
    f.close()
    j'ai bien en sortie
    et pas toutes les données qui s'affichent

  10. #10
    Membre émérite

    Profil pro
    Inscrit en
    Août 2004
    Messages
    723
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2004
    Messages : 723
    Par défaut
    C'est bien ce qui a été dit, ça ça fonctionne, ce qui ne fonctionne pas c'est d'accéder à une ligne par f_csv[0] par exemple :
    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
    >>> import csv
    >>> fd = open('1.csv', 'r')
    >>> f_csv = csv.reader(fd, delimiter = ';')
    >>> print f_csv
    <_csv.reader object at 0x819d56c>
    >>> print f_csv[0]
    Traceback (most recent call last):
      File "<stdin>", line 1, in <module>
    TypeError: '_csv.reader' object is unsubscriptable
    >>> for l in f_csv:
    ...     print l
    ...
    ['1', '2', '3', '4']
    ['5', '6', '7', '8']
    >>> fd.close()

  11. #11
    Membre chevronné
    Homme Profil pro
    Inscrit en
    Mai 2002
    Messages
    309
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Meurthe et Moselle (Lorraine)

    Informations forums :
    Inscription : Mai 2002
    Messages : 309
    Par défaut
    Citation Envoyé par oiffrig Voir le message
    Pas compris là Tu peux préciser ce que tu veux dire ?
    Je dis la même chose que toi, mais tu explique bien miux que moi !

  12. #12
    Membre émérite
    Homme Profil pro
    Inscrit en
    Janvier 2006
    Messages
    491
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Corse (Corse)

    Informations forums :
    Inscription : Janvier 2006
    Messages : 491
    Par défaut
    ok , quand on m'explique longtemps je comprend rapidement
    merci
    tres bien le 'list'

  13. #13
    Membre du Club
    Inscrit en
    Avril 2008
    Messages
    7
    Détails du profil
    Informations forums :
    Inscription : Avril 2008
    Messages : 7
    Par défaut
    Je vous remercie pour les réponses,
    En fait mon code est parfaitement identique à celui de Xavier, donc je ne me mélangeais pas les pinceaux . Toutefois, le format du fichier csv n'est pas le même!! je devrais donc changer la configuration de mon tableur, et on verra.
    par ailleurs, j'aime bien l'astuce de list.

Discussions similaires

  1. Importation données de Excel vers Access (ADO)
    Par DAEM86 dans le forum Bases de données
    Réponses: 6
    Dernier message: 30/11/2012, 17h03
  2. Importer un objet c++ vers Python
    Par Blustuff dans le forum Interfaçage autre langage
    Réponses: 8
    Dernier message: 02/08/2011, 11h04
  3. Importer données de access vers vb
    Par prison_break dans le forum VB 6 et antérieur
    Réponses: 18
    Dernier message: 02/08/2007, 15h17
  4. [débutant] importation de données d'excel vers table
    Par vivelesgnous dans le forum Access
    Réponses: 6
    Dernier message: 24/02/2006, 21h13
  5. Importation d'une base de donnée sql server vers oracle
    Par delphy456 dans le forum MS SQL Server
    Réponses: 9
    Dernier message: 17/01/2006, 14h44

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