ファイル内に次の JSON があります:
{
"maps": [
{
"id": "blabla",
"iscategorical": "0"
},
{
"id": "blabla",
"iscategorical": "0"
}
],
"masks": [
"id": "valore"
],
"om_points": "value",
"parameters": [
"id": "valore"
]
}
すべての JSON データを印刷するために、次のスクリプトを作成しました。
import json
from pprint import pprint
with open('data.json') as f:
data = json.load(f)
pprint(data)
ただし、このプログラムでは例外が発生します。
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)
JSON を解析してその値を抽出するにはどうすればよいですか?
ベストアンサー1
データは無効です翻訳形式。要素と要素には[]
次のものが必要です。{}
"masks"
"parameters"
[]
JSON配列用で、list
Pythonでは次のように呼ばれます{}
dict
JSONオブジェクト用で、 Pythonで呼び出されます
JSON ファイルは次のようになります。
{
"maps": [
{
"id": "blabla",
"iscategorical": "0"
},
{
"id": "blabla",
"iscategorical": "0"
}
],
"masks": {
"id": "valore"
},
"om_points": "value",
"parameters": {
"id": "valore"
}
}
次に、コードを使用します:
import json
from pprint import pprint
with open('data.json') as f:
data = json.load(f)
pprint(data)
データを使用すると、次のような値も見つけられるようになりました。
data["maps"][0]["id"]
data["masks"]["id"]
data["om_points"]
これらを試してみて、意味がわかるかどうか確認してください。