无法解析json内容错误`期望属性名称封闭`

时间:2016-03-14 15:53:24

标签: python json python-3.x

我从数据库中获取了一个json格式的文本。基本上将api内容从网站转储到带有TEXT字段的数据库。

我可以看到json内容没有问题/错误,但是当我这样做时。

try:
    get_all = db.query("SELECT id, name, api_content FROM _books")
    _result = get_all.fetchall()
except Exception as e:
    print("[e::line-163] ", e)

try:
    for r in _result:
        api_content = r[2]
        j = json.loads(api_content)
        print('names, ', j['names'])

我收到此错误。

  

期望用双引号括起来的属性名称:第1行第2列(字符1)

api_content没有问题,它是一个结构良好的json内容。

1 个答案:

答案 0 :(得分:2)

我认为api_content中没有有效的JSON。根据错误的内容来判断,您的属性(键)用单引号括起来,但需要用双引号括起来作为有效的JSON。

以下是发生的事情:

>>> import json
>>> json.loads('{"key": "value"}')  # <- VALID JSON
{'key': 'value'}
>>> json.loads("{'key': 'value'}")  # <- INVALID JSON
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
  File "/Library/Frameworks/Python.framework/Versions/3.5/lib/python3.5/json/__init__.py", line 319, in loads
    return _default_decoder.decode(s)
  File "/Library/Frameworks/Python.framework/Versions/3.5/lib/python3.5/json/decoder.py", line 339, in decode
    obj, end = self.raw_decode(s, idx=_w(s, 0).end())
  File "/Library/Frameworks/Python.framework/Versions/3.5/lib/python3.5/json/decoder.py", line 355, in raw_decode
    obj, end = self.scan_once(s, idx)
json.decoder.JSONDecodeError: Expecting property name enclosed in double quotes: line 1 column 2 (char 1)

换句话说,您应该修改将API内容转储到数据库中的方式。看起来您只是在编写Python字典对象的字符串表示而不是使用json.dumps()

如果您无法更改,请尝试使用ast.literal_eval()安全地评估api内容:

from ast import literal_eval

for r in _result:
    api_content = r[2]
    j = literal_eval(api_content)
    print('names, ', j['names'])