环境
- Ubuntu 16.04 LTS
- python3.x
问题描述
-
从字符串转换为json对象时,报错如下:
Traceback (most recent call last): File "<stdin>", line 1, in <module> 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 357, in raw_decode raise JSONDecodeError("Expecting value", s, err.value) from None json.decoder.JSONDecodeError: Expecting value: line 1 column 6 (char 5)
-
示例代码:
import json str_json = '{"a":NULL, "b":1}' json_data = json.loads(str_json)
错误原因分析
str_json中从第5个字符开始是非法字符,也就是’NULL’
【】总之,这类错误就说明是json字符串是非法的:比如格式错误、值类型错误等
解决方案
-
1、使用try抛出异常,跳过错误数据
import json str_json = '{"a":NULL, "b":1}' try: json_data = json.loads(str_json) except Exception as e: print('error:', e)
输出:
error: Expecting value: line 1 column 6 (char 5)
-
2、从源头解决
数据转为json字符串时,使用json.dumps()函数,加载字符串为对象时用json.loads
import json json_data = {"a":None, "b":1} print('json_data:', json_data) str_json = json.dumps(json_data) #使用json.dumps()函数 print('str_json:', str_json) json_data = json.loads(str_json) print('json_data:', json_data)
输出:
json_data: {'a': None, 'b': 1} str_json: {"a": null, "b": 1} json_data: {'a': None, 'b': 1}
可以看到 str_json 中出现 null ,而不是 None/NULL。