web-dev-qa-db-fra.com

Lire JSON à partir d'un fichier?

Je commence à avoir un peu mal à la tête simplement parce qu’une déclaration simple et facile me lance des erreurs au visage.

J'ai un fichier json appelé strings.json comme ceci:

"strings": [{"-name": "city", "#text": "City"}, {"-name": "phone", "#text": "Phone"}, ...,
            {"-name": "address", "#text": "Address"}]

Je veux lire le fichier JSON, rien que pour le moment. J'ai ces déclarations que j'ai découvertes, mais ça ne marche pas:

import json
from pprint import pprint

with open('strings.json') as json_data:
    d = json.load(json_data)
    json_data.close()
    pprint(d)

L'erreur affichée sur la console était la suivante:

Traceback (most recent call last):
File "/home/.../Android/values/manipulate_json.py", line 5, in <module>
d = json.loads(json_data)
File "/usr/lib/python2.7/json/__init__.py", line 326, in loads
return _default_decoder.decode(s)
File "/usr/lib/python2.7/json/decoder.py", line 366, in decode
obj, end = self.raw_decode(s, idx=_w(s, 0).end())
TypeError: expected string or buffer
[Finished in 0.1s with exit code 1]

édité

Changé de json.loads en json.load

et obtenu ceci:

Traceback (most recent call last):
File "/home/.../Android/values/manipulate_json.py", line 5, in <module>
d = json.load(json_data)
File "/usr/lib/python2.7/json/__init__.py", line 278, in load
**kw)
File "/usr/lib/python2.7/json/__init__.py", line 326, in loads
return _default_decoder.decode(s)
File "/usr/lib/python2.7/json/decoder.py", line 369, in decode
raise ValueError(errmsg("Extra data", s, end, len(s)))
ValueError: Extra data: line 829 column 1 - line 829 column 2 (char 18476 - 18477)
[Finished in 0.1s with exit code 1]
275
R.R.C.

La méthode json.load() (sans "s" dans "load") peut lire un fichier directement:

import json

with open('strings.json') as f:
    d = json.load(f)
    print(d)

Vous utilisiez la méthode json.loads() , utilisée uniquement pour les arguments chaîne.

Edit: Le nouveau message est un problème totalement différent. Dans ce cas, il y a du json invalide dans ce fichier. Pour cela, je vous recommande d'exécuter le fichier avec un json validator .

Il existe également des solutions pour réparer JSON, comme par exemple Comment puis-je réparer automatiquement une chaîne JSON non valide? .

474
ubomb

Voici une copie du code qui fonctionne bien pour moi

import json

with open("test.json") as json_file:
    json_data = json.load(json_file)
    print(json_data)

avec les données

{
    "a": [1,3,"asdf",true],
    "b": {
        "Hello": "world"
    }
}

vous souhaiterez peut-être envelopper votre ligne json.load avec un test try, car un JSON non valide entraînera un message d'erreur stacktrace.

108
user1876508

Le problème est d'utiliser avec déclaration:

with open('strings.json') as json_data:
    d = json.load(json_data)
    pprint(d)

Le fichier va déjà être implicitement fermé. Il n'est pas nécessaire d'appeler à nouveau json_data.close().

40
Zongjun

Dans python 3, nous pouvons utiliser la méthode ci-dessous.

Lire à partir du fichier et convertir en JSON

import json

# Considering "json_list.json" is a json file

with open('json_list.json') as fd:
     json_data = json.load(fd)

ou

import json

json_data = json.load(open('json_list.json'))

L'utilisation de l'instruction with fermera automatiquement le descripteur de fichier ouvert.

Chaîne vers JSON

import json

json_data = json.loads('{"name" : "myName", "age":24}')
21
Thejesh PR

Pour ajouter ceci, vous pouvez aujourd'hui utiliser pandas pour importer json:
https://pandas.pydata.org/pandas-docs/stable/generated/pandas.read_json.html Vous voudrez peut-être utiliser le paramètre orient avec précaution.

3
Ando Jurai