视频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:20:46 责编:小采
文档


本篇文章给大家带来的内容是关于Python中json模块和pickle模块的简单介绍(附示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

Python中的json模块和pickle都是用于数据的序列化和反序列化,它们提供的方法也是一样的:dumps,dump,loads,load

  • dumps(obj):将对象序列化为str。

  • dump(obj, fp):将对象序列化为str,并存入文件中。

  • loads(s):将(序列化后的)字符串反序列化为Python对象。

  • load(fp):将文件中的(序列化后的)字符串反序列化为Python对象。

  • json和pickle模块虽然都是用于数据的序列化和反序列化,但它们之间还是有许多区别的,或者说各有各的优点和缺点:

  • 通用性:json序列化后的字符串是通用的格式(普通的字符串)在中不同的平台和语言都可以识别,而pickle序列化后的字符串只有Python可以识别(Python专用序列化模块)

  • 处理的数据类型:json能序列化的对象只是Python中基础数据类型,而pickle能序列化Python中所有的数据类型。

  • 处理后的数据类型:json序列化后的字符串是文本类型(记事本打开文件后或者print打印后,你也能看懂其中的内容),而pickle序列化后的字符串是二进制流数据(记事本打开后或者print打印后就完全看不懂里面的内容了)。所以在进行文件操作时注意使用的是哪个模块,是否需要以b的格式打开。

  • 使用空间:json需要的存储空间较小,pickle需要的存储空间较大。

  • 以下是pickle文件操作的一个简单示例:

    >>> import pickle
    >>> dic = {'a': 111, 'b': 222, 'c': 333}
    >>> f = open('D:/pk_file.pk', 'wb')
    >>> lst = [1, 2, 4, 5]
    >>> # 将字典对象和列表对象序列化,并存入文件,文件名后缀自定义为.pk
    >>> pickle.dump(dic, f)
    >>> pickle.dump(lst, f)
    >>> f.close()
    >>> # 将文件中的Python对象按写入顺序读取出来,且一次读取一个对象
    >>> pk_f = open('D:/pk_file.pk', 'rb')
    >>> result = pickle.load(pk_f)
    >>> type(result)
    <class 'dict'>
    >>> result
    {'a': 111, 'b': 222, 'c': 333}
    >>> other_result = pickle.load(pk_f)
    >>> type(other_result)
    <class 'list'>
    >>> other_result
    [1, 2, 4, 5]
    >>>

    下载本文
    显示全文
    专题