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 :

utilisation d'un fichier json en python


Sujet :

Python

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    321
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2006
    Messages : 321
    Points : 109
    Points
    109
    Par défaut utilisation d'un fichier json en python
    bonjour,

    j'essaye d'utiliser un fichier json (fichier shape exporter à partir de gdal) la prmière ligne de mon fichier ressemble à cela>>
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    {
    "type": "FeatureCollection",
     
    "features": [
    { "type": "Feature", "properties": { "CD": "27N675", "CODE": "N675" }, "geometry": { "type": "Polygon", "coordinates": [ [ [ -269999.99998149002, 6750000.0001561129 ], [ -269999.99998149002, 6760000.0003807945 ], [ -259999.99975680845, 6760000.0003807945 ], [ -259999.99975680845, 6750000.0001561129 ], [ -269999.99998149002, 6750000.0001561129 ] ] ] } },
    lire de fichier ne présente pas de problème
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    fichier="mon.json"
    with open(fichier,'r') as f:
        get_id=json.load(f)
        print get_id
    mais j'aimerais pouvoir accéder à certaines données seulement mais j'ai tjrs l'erreur "KeyError:". je croyais que "CD" était la clé et la valeur "27N675" mais appremment non puisqu'il me renvoie une erreur.
    si quelqu'un pouvait m'expliquer la manière de fonctionner de de dictionnaire, ce serait sympa???

    merci

  2. #2
    Expert éminent sénior
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 281
    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 281
    Points : 36 768
    Points
    36 768
    Par défaut
    Salut,

    La structure de vos données est beaucoup plus complexe qu'un simple "dictionnaire": il faut galérer un peu pour arriver à...
    Essayez de poster le contenu du vrai fichier JSON.

    Lis les Cours et tutoriels pour apprendre la programmation Python , par exemple : Apprendre à programmer avec Python 3 par Gérard Swinnen


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

  3. #3
    Expert éminent

    Homme Profil pro
    Inscrit en
    Octobre 2008
    Messages
    4 300
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Octobre 2008
    Messages : 4 300
    Points : 6 780
    Points
    6 780
    Par défaut
    Salut,

    Aucun problème:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    >>> import json
    >>> with open('tst.json','r') as inf:
    ...     js = json.load(inf)
    ... 
    >>> js
    {u'type': u'FeatureCollection', u'features': [{u'geometry': {u'type': u'Polygon', u'coordinates': [[-269999.99998149, 6750000.000156113], [-269999.99998149, 6760000.0003807945], [-259999.99975680845, 6760000.0003807945], [-259999.99975680845, 6750000.000156113], [-269999.99998149, 6750000.000156113]]}, u'type': u'Feature', u'properties': {u'CODE': u'N675', u'CD': u'27N675'}}]}
    >>> js['features'][0]['properties']['CD']
    u'27N675'
    >>>

  4. #4
    Membre régulier
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    321
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2006
    Messages : 321
    Points : 109
    Points
    109
    Par défaut
    cool .. merci vinss. j'essayais de trouver l'index sur cd[0].. je comprend mieux comment utiliser ce dico..

    merci

  5. #5
    Membre régulier
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    321
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2006
    Messages : 321
    Points : 109
    Points
    109
    Par défaut
    je crois que j'ai mis résolu un peu trop vite..

    car je veux pouvoir avoir tte les valeurs d'un champ..
    j'ai essayer js['features'][0:]['properties']['CD']

    mais j'ai l'erreur TypeError: list indices must be integers, not str

    le type de fichier est bien ce que 'lon appelle un dictionnaire de liste??du coup si vous avez quelques tuto qui en parle ou si vous avez le temps de me donner quelques explication supplémentaires, ce n'est pas de refus...

    merci

  6. #6
    Expert éminent

    Homme Profil pro
    Inscrit en
    Octobre 2008
    Messages
    4 300
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Octobre 2008
    Messages : 4 300
    Points : 6 780
    Points
    6 780
    Par défaut
    C'est sans doute parce que tu as deux listes imbriquées.

    Quand j'ai repris ton exemple, comme c'était un extrait je l'ai "nettoyé".

    Si tu essayes ceci:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    js['features'][0][0]['properties']['CD']
    c'est mieux ?

    Par contre quand tu dis que tu veux toutes les valeurs d'un champ je ne saisis pas. Un exemple ?

  7. #7
    Membre régulier
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    321
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2006
    Messages : 321
    Points : 109
    Points
    109
    Par défaut
    salut,

    js['features'][0][0]['properties']['CD'] cela me donne une erreur key


    en fait j'ai un fichier d'un format "shape" que je transforme avec gdal en mon.json. et j'essaye de réaliser une jointure avec un csv. (pandas)
    Dans ce csv j'ai aussi un champ 'cd' et j'essaye de n'afficher sur mon.jason que les valeurs du champ "cd" que je retrouve dans mon csv....

    et pour cela j'essaie de comprendre comment utiliser ce dico que je ne maîtrise pas du tout

  8. #8
    Membre régulier
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    321
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2006
    Messages : 321
    Points : 109
    Points
    109
    Par défaut
    ok je les ai récupérés comme ceci

    [x['properties']['CD'] for x in get_id['features']]

Discussions similaires

  1. Utilisation d'un fichier OCX avec Python
    Par yoyo29 dans le forum Interfaçage autre langage
    Réponses: 1
    Dernier message: 10/03/2010, 15h28
  2. Connaître les constantes utilisées dans un fichier Python
    Par rambc dans le forum Général Python
    Réponses: 1
    Dernier message: 20/07/2009, 13h13
  3. utilisation d'un fichier log
    Par portu dans le forum Windows
    Réponses: 3
    Dernier message: 16/09/2004, 10h34
  4. [struts] utilisation de plusieurs fichiers de config
    Par Boosters dans le forum Struts 1
    Réponses: 4
    Dernier message: 25/03/2004, 10h04
  5. utiliser le même fichier dans plusieurs projets vc++6
    Par yannick_sch dans le forum MFC
    Réponses: 5
    Dernier message: 12/02/2004, 17h39

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