Ich habe dieses JSON in einer Datei:
{
"maps": [
{
"id": "blabla",
"iscategorical": "0"
},
{
"id": "blabla",
"iscategorical": "0"
}
],
"masks": [
"id": "valore"
],
"om_points": "value",
"parameters": [
"id": "valore"
]
}
Ich habe dieses Skript geschrieben, um alle JSON-Daten zu drucken:
import json
from pprint import pprint
with open('data.json') as f:
data = json.load(f)
pprint(data)
Dieses Programm löst jedoch eine Ausnahme aus:
Traceback (most recent call last):
File "<pyshell#1>", line 5, in <module>
data = json.load(f)
File "/usr/lib/python3.5/json/__init__.py", line 319, in loads
return _default_decoder.decode(s)
File "/usr/lib/python3.5/json/decoder.py", line 339, in decode
obj, end = self.raw_decode(s, idx=_w(s, 0).end())
File "/usr/lib/python3.5/json/decoder.py", line 355, in raw_decode
obj, end = self.scan_once(s, idx)
json.decoder.JSONDecodeError: Expecting ',' delimiter: line 13 column 13 (char 213)
Wie kann ich das JSON parsen und seine Werte extrahieren?
Ihre Daten haben ein ungültiges JSON Format. Sie haben []
, wenn Sie {}
haben sollten:
[]
sind für JSON-Arrays, die in Python list
genannt werden{}
sind für JSON-Objekte, die in Python dict
genannt werdenSo sollte Ihre JSON-Datei aussehen:
{
"maps": [
{
"id": "blabla",
"iscategorical": "0"
},
{
"id": "blabla",
"iscategorical": "0"
}
],
"masks": {
"id": "valore"
},
"om_points": "value",
"parameters": {
"id": "valore"
}
}
Dann können Sie Ihren Code verwenden:
import json
from pprint import pprint
with open('data.json') as f:
data = json.load(f)
pprint(data)
Mit Daten können Sie nun auch Werte wie diese finden:
data["maps"][0]["id"]
data["masks"]["id"]
data["om_points"]
Probieren Sie diese aus und sehen Sie, ob es Sinn macht.
Ihre data.json
sollte wie folgt aussehen:
{
"maps":[
{"id":"blabla","iscategorical":"0"},
{"id":"blabla","iscategorical":"0"}
],
"masks":
{"id":"valore"},
"om_points":"value",
"parameters":
{"id":"valore"}
}
Ihr Code sollte so aussehen:
import json
from pprint import pprint
with open('data.json') as data_file:
data = json.load(data_file)
pprint(data)
Beachten Sie, dass dies nur in Python 2.6 und höher funktioniert, da es von der with
-Anweisung abhängt. In Python 2.5 verwenden Sie from __future__ import with_statement
, in Python <= 2.4, siehe Justin Peel's answer, auf dem diese Antwort basiert.
Sie können nun auch auf einzelne Werte wie folgt zugreifen:
data["maps"][0]["id"] # will return 'blabla'
data["masks"]["id"] # will return 'valore'
data["om_points"] # will return 'value'
data = []
with codecs.open('d:\output.txt','rU','utf-8') as f:
for line in f:
data.append(json.loads(line))