Python がこの JSON データを解析できないのはなぜですか? [closed] 質問する

Python がこの JSON データを解析できないのはなぜですか? [closed] 質問する

ファイル内に次の 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配列用で、listPythonでは次のように呼ばれます
  • {}dictJSONオブジェクト用で、 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"]

これらを試してみて、意味がわかるかどうか確認してください。

おすすめ記事