博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
6.python序列化功能之json&pickle
阅读量:6608 次
发布时间:2019-06-24

本文共 1103 字,大约阅读时间需要 3 分钟。

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只能持久化一些比较简单的数据类型,比如,字符串,列表,元组,字典等。

      本文转自苏浩智 51CTO博客,原文链接:http://blog.51cto.com/suhaozhi/1910425,如需转载请自行联系原作者
你可能感兴趣的文章
rpm安装PostgreSQL
查看>>
k sum(lintcode)
查看>>
28. extjs中Ext.BLANK_IMAGE_URL的作用
查看>>
Hibernate注解配置N:N关联
查看>>
Android 控件属性
查看>>
java进程卡死问题
查看>>
【244】◀▶IEW-Unit09
查看>>
处理有外键约束的数据
查看>>
par函数的xaxt函数-控制x轴刻度的显示
查看>>
Unity5.1 新的网络引擎UNET(十五) Networking 引用--中
查看>>
用任务计划管理计划任务对付任务计划-禁止WPS提示升级
查看>>
Android——SlidingMenu学习总结
查看>>
React-Native 之 GD (十六)首页筛选功能
查看>>
UI概念体系要素
查看>>
SSISDB5:使用TSQL脚本执行Package
查看>>
performSelectorInBackground V.S detachNewThreadSelector?
查看>>
linux,Centos,bash: service: command not found
查看>>
【转】UIColor对颜色的自定义
查看>>
php编译报错 configure: error: Please reinstall the libcurl distribution - easy.h should be in <curl-...
查看>>
asp.net后台进程做定时任务
查看>>