python学习之序列化
序列化:不同编程语言之间传递对象需要序列化成标准格式,有XML /JSON,json格式化为字符串,UTF-8编码,速度快,切实标准格式。JSON 和 Python
内置的数据类型对应如下:
JSON 类型 | Python 类型 |
{} | dict |
[] | list |
"string" | str |
1234.56 | int 或 float |
true/false | True/False |
null | None |
pickling /unpickling :指的是内存变化的量存到磁盘或进行传输,反序列化指的是从磁盘或网络传输到内存。
相关模块:pickle JSON
相关函数:
序列化:pickle.dumps()方法把任意对象序列化成一个 bytes ;pickle.dump()直接把对象序列化 后写入一个 file-like Object ;
dumps()方法返回一个 str
pickle.loads()方法反序列化出对象,也可以直接用 pickle.load()方法从一个 file-like Object 中直接反序列化出对象
;
用 loads()或者对应的 load()方法,把 JSON 的字符串反序列化
print(json.dumps(s, default=lambda obj: obj.__dict__)) #把类序列化需要制定何种格式序列化。