Kāpēc Python nevar analizēt šos JSON datus?

Man šis JSON ir saglabāts failā:

{
    "maps": [
        {
            "id": "blabla",
            "iscategorical": "0"
        },
        {
            "id": "blabla",
            "iscategorical": "0"
        }
    ],
    "masks": [
        "id": "valore"
    ],
    "om_points": "value",
    "parameters": [
        "id": "valore"
    ]
}

Es uzrakstīju šo skriptu, lai izdrukātu visus JSON datus:

import json
from pprint import pprint

with open('data.json') as f:
    data = json.load(f)

pprint(data)

Tomēr šī programma rada izņēmumu:

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)

Kā es varu analizēt JSON un iegūt tā vērtības?

Risinājums

Jūsu dati nav derīgs JSON formāts. Jums ir [], lai gan vajadzētu būt {}:

  • [] ir domāts JSON masīviem, kurus Python valodā sauc par list.
  • {} ir JSON objektiem, kurus Python valodā sauc par dict.

Lūk, kā jāizskatās jūsu JSON failam:

{
    "maps": [
        {
            "id": "blabla",
            "iscategorical": "0"
        },
        {
            "id": "blabla",
            "iscategorical": "0"
        }
    ],
    "masks": {
        "id": "valore"
    },
    "om_points": "value",
    "parameters": {
        "id": "valore"
    }
}

Tad varat izmantot savu kodu:

import json
from pprint import pprint

with open('data.json') as f:
    data = json.load(f)

pprint(data)

Izmantojot datus, tagad varat atrast arī šādas vērtības:

data["maps"][0]["id"]
data["masks"]["id"]
data["om_points"]

Izmēģiniet šīs vērtības un paskatieties, vai tas sāk būt jēgpilni.

Komentāri (14)

Jūsu data.json vajadzētu izskatīties šādi:

{
 "maps":[
         {"id":"blabla","iscategorical":"0"},
         {"id":"blabla","iscategorical":"0"}
        ],
"masks":
         {"id":"valore"},
"om_points":"value",
"parameters":
         {"id":"valore"}
}

Jūsu kodam jābūt:

import json
from pprint import pprint

with open('data.json') as data_file:    
    data = json.load(data_file)
pprint(data)

Ņemiet vērā, ka tas darbojas tikai Python 2.6 un jaunākajās versijās, jo ir atkarīgs no with-teikuma. Python 2.5 lietojiet from __future__ import with_statement, Python

Komentāri (7)
data = []
with codecs.open('d:\output.txt','rU','utf-8') as f:
    for line in f:
       data.append(json.loads(line))
Komentāri (5)