:mod:`ujson` -- JSON 编码和解码 ========================================== .. module:: ujson :synopsis: JSON 编码和解码 这个模块实现了相应 :term:`CPython` 模块的一个子集,如下所述。有关更多信息,请参阅原始CPython文档: `json `_ 此模块允许在Python对象和JSON数据格式之间进行转换。 函数 --------- .. function:: dump(obj, stream) 将 *obj* 串行化为 *JSON* 字符串,将其写入给定的 *stream* 。 .. function:: dumps(obj) 将dict类型的数据转换成str,因为如果直接将dict类型的数据写入json文件中会发生报错,因此在将数据写入时需要用到该函数。 - ``obj`` 要转换的对象 示例:: >>> obj = {1:2, 3:4, "a":6} >>> print(type(obj), obj) #原来为dict类型 {3: 4, 1: 2, 'a': 6} >>> jsObj = ujson.dumps(obj) #将dict类型转换成str >>> print(type(jsObj), jsObj) {3: 4, 1: 2, "a": 6} .. function:: load(stream) 解析给定的 *stream* ,将其解释为JSON字符串并将数据反序列化为Python对象。返回结果对象。 解析继续,直到遇到文件结尾。如果未正确形成流中的数据,则引发 :exc:`ValueError` .. function:: loads(str) 解析 JSON 字符串并返回对象。如果字符串格式错误将引发 ValueError 异常。 示例:: >>> obj = {1:2, 3:4, "a":6} >>> jsDumps = ujson.dumps(obj) >>> jsLoads = ujson.loads(jsDumps) >>> print(type(obj), obj) {3: 4, 1: 2, 'a': 6} >>> print(type(jsDumps), jsDumps) {3: 4, 1: 2, "a": 6} >>> print(type(jsLoads), jsLoads) {'a': 6, 1: 2, 3: 4}