使用json.loads,解析以下数据为json格式时,报错

a = [{'start_city': '1', 'end_city': 'aaa', 'number': 1},
     {'start_city': '2', 'end_city': 'bbb', 'number': 1},
     {'start_city': '3', 'end_city': 'ccc', 'number': 1}]

报错提示:ValueError: Expecting property name: line 1 column 2 (char 1)

代码如下

a = "[{'start_city': '1', 'end_city': 'aaa', 'number': 1},\
     {'start_city': '2', 'end_city': 'bbb', 'number': 1},\
     {'start_city': '3', 'end_city': 'ccc', 'number': 1}]"

import json

json.loads(a)

原因是为什么?

        这要先从json格式什么来讲。

        JSON是一种取代XML的数据结构,和xml相比,它更小巧但描述能力却不差,由于它的小巧所以网络传输数据将减少更多流量从而加快速度。

        JSON就是一串字符串 只不过元素会使用特定的符号标注。

        {} 双括号表示对象

        [] 中括号表示数组

        "" 双引号内是属性或值

        : 冒号表示后者是前者的值(这个值可以是字符串、数字、也可以是另一个数组或对象)

        所以 {"name": "Michael"} 可以理解为是一个包含name为Michael的对象

        而[{"name": "Michael"},{"name": "Jerry"}]就表示包含两个对象的数组

        当然了,你也可以使用{"name":["Michael","Jerry"]}来简化上面一部,这是一个拥有一个name数组的对象

【特别提醒:现在还有很多人存在一些误区,为什么{name:’json’}在检验时通过不了,那是因为JSON官网最新规范规定:如果是字符串,那不管是键或值最好都用双引号引起来,所以上面的代码就是{“name”:”json”}】

所以在python中json.loads无法解析单号,就会提示错误ValueError: Expecting property name: line 1 column 3 (char 2)

解决办法如下:

        1.使用ast方法,最安全方法

In [15]: a = "[{'start_city': '1', 'end_city': 'aaa', 'number': 1},\
    ...:      {'start_city': '2', 'end_city': 'bbb', 'number': 1},\
    ...:      {'start_city': '3', 'end_city': 'ccc', 'number': 1}]"

In [16]: import ast

In [17]: ast.literal_eval(a)
Out[17]:
[{'end_city': 'aaa', 'number': 1, 'start_city': '1'},
 {'end_city': 'bbb', 'number': 1, 'start_city': '2'},
 {'end_city': 'ccc', 'number': 1, 'start_city': '3'}]

        2.最笨方法使用replace,把单引号转换为双引号,

In [35]: strs = "{'key':'val'}"

In [36]: strs = strs.replace("'",'"')

In [37]: json.loads(strs)
Out[37]: {u'key': u'val'}

        3. 最方便方法,但是会有安全隐患方法

        请参考文章:python 为什么说eval要慎用?使用eval 带来的潜在风险?什么情况下使用eval?

In [38]: a = "[{'start_city': '1', 'end_city': 'aaa', 'number': 1},\
    ...:      {'start_city': '2', 'end_city': 'bbb', 'number': 1},\
    ...:      {'start_city': '3', 'end_city': 'ccc', 'number': 1}]"

In [39]: eval(a)
Out[39]:
[{'end_city': 'aaa', 'number': 1, 'start_city': '1'},
 {'end_city': 'bbb', 'number': 1, 'start_city': '2'},
 {'end_city': 'ccc', 'number': 1, 'start_city': '3'}]

原文:http://www.chenxm.cc/post/328.html

GitHub 加速计划 / js / json
41.72 K
6.61 K
下载
适用于现代 C++ 的 JSON。
最近提交(Master分支:1 个月前 )
960b763e 4 个月前
8c391e04 6 个月前
Logo

旨在为数千万中国开发者提供一个无缝且高效的云端环境,以支持学习、使用和贡献开源项目。

更多推荐