视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
python序列化功能之json&pickle的详细介绍
2020-11-27 14:24:53 责编:小采
文档


json模块是个非常重要的模块,可以实现任何语言之间跨平台的数据交换,还可以实现一些比较简单的数据类型的持久化。(这里的持久化就是说,把python内部一些比较简单的数据类型,比如说像字符串,列表,元组,字典之类的数据类型,转换为json字符串的标准格式,保存到硬盘中。)

json模块常用函数:

json.dumps():将python以字典为主的数据类型,包括(列表,元组,等)转换为json字符串。

json.loads():将json字符串转换为python可识别的数据类型。

json.dump():将python以字典为主的数据类型,包括(列表,元组,字符串)转换为json字符串,并且通过文件句柄,将转换后的json字符串写入到文件中。

json.load():通过文件句柄,直接从文件中读取json字符串,然后转换为python可识别的数据类型。

pickle模块,只支持python程序之间的的数据交换,可以将python中一些比较复杂的数据类型,持久化。

(pickle不仅可以将字典,列表,元组,之类比较简单的数据类型保存到硬盘,还可以持久化一些比较复杂的数据类型,比如函数,类,对象等都可以存放到硬盘!)

pickle模块的常用函数:

(pickle模块常用的函数作用和json是一样的)

pickle.dumps():将python中的数据类型转换为特殊字符串或者字节(注意!在python2.7版本中pickle.dumps会将python的数据类型转换为不可读的字符串类型,在python3以上的版本使用pickle.dumps函数会直转换为bytes字节。)

pickle.loads():用于解析被pickle转换过的python数据类型。

pickle.dump()作用和dumps一样,只不过是直接通过文件句柄写入到文件中。

pickle.load()直接从文件中读取字节,解析成python可识别的数据类型。

最后总结下json模块和pickle模块的特点:

json和pickle都可以做到数据类型序列化和持久化功能。

json可以做跨平台(跨语言)的数据交换,pickle不能,pickle只能实现python和python之间的数据交换。

pickle几乎可以持久化python中所有的数据类型,类,对象,函数都可以,但是json做不到,json只能持久化一些比较简单的数据类型,比如,字符串,列表,元组,字典等。

下载本文
显示全文
专题