json—Json编解码
JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式,易于人阅读和编写。Python使用json库编解码JSON对象:json
提供了与标准库marshal
和pickle
相似的API接口。
注意:json
模块总是会产生str
对象,而不是 bytes
对象。
函数 | 描述 |
---|---|
json.dumps | 将 Python 对象编码成 JSON 字符串 |
json.loads | 将已编码的 JSON 字符串解码为 Python 对象 |
json.dump | 将 Python 对象编码成JSON字符串并将其输出到fp |
json.load | 将一个fp反序列化为一个 Python 对象 |
-
json.dumps(obj, *, skipkeys=False, ensure_ascii=True, check_circular=True, allow_nan=True, cls=None, indent=None, separators=None, default=None, sort_keys=False, **kw)
参数解析:
- skipkeys:如果 skipkeys 是
True
,那么那些不是基本对象(包括str
,int
、float
、bool
、None
)的字典的键会被跳过;否则引发一个TypeError
。 - ensure_ascii:如果ensure_ascii为
True
,则保证输出转义所有传入的非ASCII字符。如果ensure_ascii为False
,则这些字符将按原样输出。 - allow_nan:如果 allow_nan 是
False
,那么在对严格 JSON 规格范围外的float
类型值(nan
、inf
和-inf
)进行序列化时会引发一个ValueError
。如果 allow_nan 是True
,则使用它们的 JavaScript 等价形式(NaN
、Infinity
和-Infinity
)。 - indent:如果indent是非负整数或字符串,那么JSON数组元素和对象成员将使用该缩进级别进行漂亮打印。缩进级别为0,为负,或
""
仅插入换行符。None
(默认值)选择最紧凑的表示。使用正整数缩进缩进每个级别的许多空格。如果indent是一个字符串(例如"\t"
),则该字符串用于缩进每个级别。 - check_circular:如果check_circular为
False
(默认值*?*True
,则将跳过对容器类型的循环引用检查,并且循环引用将导致OverflowError
。 - separators:separators 应当是一个
(item_separator, key_separator)
元组,以紧凑输出。 - sort_keys:如果sort_keys为
True
,则字典的输出将按键排序。
- skipkeys:如果 skipkeys 是
-
json.loads(s, *, encoding=None, cls=None, object_hook=None, parse_float=None, parse_int=None, parse_constant=None, object_pairs_hook=None, **kw)
>>> import json
>>> d = dict(one="一",two="二",three="三")
>>> print(json.dumps(d,indent=4,sort_keys=True))
{
"one": "\u4e00",
"three": "\u4e09",
"two": "\u4e8c"
}
>>> json_str = json.dumps(d,indent=4,sort_keys=True,ensure_ascii=False)
>>> print(json_str)
{
"one": "一",
"three": "三",
"two": "二"
}
>>> json.loads(json_str)
{'one': '一', 'three': '三', 'two': '二'}
json.dump(obj, fp, *, skipkeys=False, ensure_ascii=True, check_circular=True, allow_nan=True, cls=None, indent=None, separators=None, default=None, sort_keys=False, **kw)
json.load(fp, *, cls=None, object_hook=None, parse_float=None, parse_int=None, parse_constant=None, object_pairs_hook=None, *kw)
>>> with open("data.json", 'w') as f:
... json.dump(L,f)
...
>>> with open("data.json", 'r') as f:
... print(json.load(f))
...
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
json 与 pickle
- json用于不同语言之间进行交互,就是用json可以跨语言,但是它的内容必须是简单的,因为不同语言虽然有共同的部分,但还是有很大差别的,所以,内容要尽量简单。
- pickle只用于python,可以用于所有的数据类型存储和取出。