此模块提供用于编码或解码数据的类和函数。这个实现试图尽可能符合JSON规范(RFC 4627),同时仍然提供许多可选的扩展,以允许限制较少的JavaScript语法。它包括完整的Unicode支持,包括UTF-32、BOM和代理项对处理。它还可以支持JavaScript的NaN和无限数值类型,以及它的“undefined”类型。它还包括一个类似lint的JSON语法验证器,用于测试JSON文本是否严格符合标准。
官方文档:https://pypi.org/project/demjson/1.6/
python中json模块能解析的对象格式是有限的,查看下面这三种格式,唯独第三种可以用json.loads方法。
# javascript中的对象,json.loads(js_json)会报错
js_json1 = "{x:1, y:2, z:3}"
# python打印出来的字典,json.loads(js_json1)会报错
py_json1 = "{'x':1, 'y':2, 'z':3}"
# 唯独这种格式,json.loads(py_json2)不会报错,得到{'x': 1, 'y': 2, 'z': 3}
py_json2 = '{"x":1, "y":2, "z":3}'
pip3 install demjson -i https://pypi.douban.com/simple
import demjson
js_json = "{x:1, y:2, z:3}"
py_json1 = "{'x':1, 'y':2, 'z':3}"
py_json2 = '{"x":1, "y":2, "z":3}'
data = demjson.decode(js_json)
print(data)
# {'y': 2, 'x': 1, 'z': 3}
data = demjson.decode(py_json1)
print(data)
# {'y': 2, 'x': 1, 'z': 3}
data = demjson.decode(py_json2)
print(data)
# {'y': 2, 'x': 1, 'z': 3}
encode | 将 Python 对象编码成 JSON 字符串 |
decode | 将已编码的 JSON 字符串解码为 Python 对象 |
import demjson
data = [{'a': 1, 'b': 2, 'c': 3, 'd': 4, 'e': 5}]
print(demjson.encode(data)) #[{"a":1,"b":2,"c":3,"d":4,"e":5}]
json = '{"a":1,"b":2,"c":3,"d":4,"e":5}';
print(demjson.decode(json)) # {'a': 1, 'b': 2, 'c': 3, 'd': 4, 'e': 5}
更多python相关使用技巧,欢迎点击关注。