環境
- 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。