广告
返回顶部
首页 > 资讯 > 后端开发 > Python >Python序列化模块之pickle与json怎么使用
  • 953
分享到

Python序列化模块之pickle与json怎么使用

2023-06-30 16:06:29 953人浏览 薄情痞子

Python 官方文档:入门教程 => 点击学习

摘要

本篇内容主要讲解“python序列化模块之pickle与JSON怎么使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Python序列化模块之pickle与json怎么使用”吧!序列化模块imp

本篇内容主要讲解“python序列化模块之pickle与JSON怎么使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习Python序列化模块之pickle与json怎么使用”吧!

    序列化模块

    import pickle

    序列化和反序列化

    把不能直接存储的数据变得可存储,这个过程叫做序列化。把文件中的数据拿出来,回复称原来的数据类型,这个过程叫做反序列化。

    在文件中存储的数据只能是字符串,或者是字节流,不能是其它的数据类型,但是如果想要将其存储就需要序列化。

    Python中的序列化模块叫做 picklePHP等其它的一些语言将其称作serialize 或者unserialize,每个语言的序列化功能可以序列化它本身的一切数据类型。

    使用场景

    现在存在一段数据,现在并不需要他,但是说不定什么时候我就要用它,那么最好的方法就是将这段数据保存起来。

    保存这段数据一般来说有那么几种方法(入库或者保存文件),但是这段数据很复杂,而保存在数据库中需要特定的数据格式,入库的话就非常的麻烦了,而且我不想破坏数据的原有格式,那么可以选择保存为文件。

    如下所示:保存文件会遇到种种的麻烦问题。

    # 这是我想要保存的一段数据lst = ['A', 'B', 'C']# 直接使用open函数不能将非字符串和非字节流的数据写入文件with open('data.txt', 'w', encoding='UTF-8') as fp :fp.write(lst)# !!! TypeError# 将数据变成字符串就破坏了原有的数据结构(如果很复杂的数据结构几乎没有复原的可能性)lst = str(lst)# 将数据变成字节流:只能将字符串变成字节流数据!

    现在就可以使用序列化功能,将数据序列化成为字节流的格式,然后存在文件当中,当需要的时候,再从文件中读取出来,然后反序列化成为数据原来的样子,而且保证原数据的数据结构没有变化。

    而且可以序列化语言当中的任何数据类型,就是说不止是基本的数据类型,还有函数、类、对象……

    dumps & loads

    dumps将任意对象序列化成bytes数据,loads将序列化成为bytes的数据反序列成数据原本的格式。

    注意:只能反序列化被序列化的数据

    import pickle# 这是我想要保存的一段数据lst = ['A', 'B', 'C']# dumps 把任意对象序列化成bytesres = pickle.dumps(lst)print(res)  # b'\x80\x03]q\x00(X\x01\x00\x00\x00Aq\x01X\x01\x00\x00\x00Bq\x02X\x01\x00\x00\x00Cq\x03e.'print(type(res))  # <class 'bytes'># 序列化后的bytes数据可以写入文件中。# loads 把任意bytes反序列化成为原来的数据lst = pickle.loads(res)print(lst)  # ['A', 'B', 'C']print(type(lst))  # <class 'list'># 尝试反序列化其它的bytes数据char = '你好'by_char = char.encode()new_char = pickle.loads(by_char)  # _pickle.UnpicklingError: invalid load key, '\xe4'.

    dump & load

    含义和上述的相同,只是这个可以直接操作io对象,省时省力。

    import pickle# 这是我想要保存的一段数据lst = ['A', 'B', 'C']# dumps 和 loads 配合文件操作# 序列化后写入文件with open('test.txt', 'wb') as fp:    data = pickle.dumps(lst)    fp.write(data)# 读取文件反序列化with open('test.txt', 'rb') as fp:    data = fp.read()    lst = pickle.loads(data)# dump 和 load 配合文件操作# 序列化写入文件with open('test.txt', 'wb') as fp:    pickle.dump(lst, fp)# 读取文件反序列化with open('test.txt', 'rb') as fp:    lst = pickle.load(fp)

    JSON序列化模块

    import json

    使用场景

    序列化后的数据,如果想在多种语言中都可以流通怎么办?每种语言都有自己的语言特性,有些语言中的数据是特有的,那么序列化后的数据该怎么流通呢?

    每种语言虽然各有自己的特点,但是几乎所以的语言都是师出同门,天下语言无不出C者。所以将每种语言共同存在的数据格式按照统一的标准去序列化就可以了,JSON诞生了。

    json一般存储为json文件。

    支持的数据类型

    python中支持JSON序列化的数据一共有八种类型:

    int、float、bool、str、list、tuple、dict、None

    JSON序列化支持这几种数据类型是因为JSON中就只支持这几种数据类型:

    如下为python中的数据类型对应json中的数据类型;

    python数据类型JSON数据类型
    intint
    floatfloat
    bool(True,False)bool(true,false)
    Nonenull
    strstr(必须双引号)
    list([])、tuple(())Array([])
    dict({})Object({})(键必须是双引号)

    注意:

    JSON中没有元组类型,所以会变成列表;

    JSON中的对象必须使用字符串作为键,所以python中的字典数据中的非字符串键,会变成对应的JSON数据然后强转成为字符串;

    import jsondict_var = {1: 1, 2.2: 2.2, False: True, '123': '123', "234": "234", None: None}json_obj = json.dumps(dict_var)dict_var = json.loads(json_obj)print(dict_var)# {'1': 1, '2.2': 2.2, 'false': True, '123': '123', '234': '234', 'null': None}

    JSON和pickle的区别

    JSON可以序列化python八种数据,序列化为字符串

    pickle可以序列化python所有的数据类型,序列化为字节流

    序列化函数

    JSON序列化函数和pickle的一样,名称和使用方法基本一样:

    方法含义
    dumps序列化
    loads反序列化
    dump序列化写入文件
    load读取文件反序列化

    这里注意一下序列化方法的几个常用参数:

    ensure_asscii 默认为True, 以ACSII格式编码,以Unicode显示;

    sort_keys 默认为True, 对字典的键进行排序

    indent默认为None, json格式化默认是一行不加缩进的,如果indent是一个正整数,就以该缩进级别进行换行,增强可视化

    import json# 开启排序dict_var = {'B': '2', 'A': '1'}print(dict_var)  # {'B': '2', 'A': '1'}json_char = json.dumps(dict_var, ensure_ascii=False, sort_keys=True)dict_var = json.loads(json_char)print(dict_var)  # {'A': '1', 'B': '2'}# 关闭排序dict_var = {'B': '2', 'A': '1'}print(dict_var)  # {'B': '2', 'A': '1'}json_char = json.dumps(dict_var, ensure_ascii=False, sort_keys=False)dict_var = json.loads(json_char)print(dict_var)  # {'B': '2', 'A': '1'}# dump 也一样哦

    json和pickle实际使用过程中的一些问题

    在对文件进行操作的时候:

    • json可以连续dump,但是不能连续load

    • pickle可以连续dump和load

    如下解释:

    # json 可以连续dump,但是不能连续loadimport json# 序列化数据lst1 = [1, 2, 3]lst2 = [4, 5, 6]lst3 = [7, 8, 9]# 序列化写入文件with open('test.json', 'w', encoding='UTF-8') as fp:    json.dump(lst1, fp)    json.dump(lst2, fp)    json.dump(lst3, fp)# 读取文件反序列化with open('test.json', 'r', encoding='UTF-8') as fp:    data1 = json.load(fp)  # ERROR    data2 = json.load(fp)    data3 = json.load(fp)# !!! json.decoder.JSONDecodeError: Extra data: line 1 column 10 (char 9)

    因为 json.dump 方法序列化写入文件的时候,写入了两个及以上的数据,之后 json.load 方法在读的时候又是一次性将整个文件中的数据读取出来,这个时候,反序列化的数据成了 [1, 2, 3][4, 5, 6][7, 8, 9] ,这明显不是一个json支持的数据格式,所以 json.load 失败了。

    再来看pickle是怎么样的:

    # pickle 可以连续dump,也可以连续loadimport pickle# 序列化数据lst1 = [1, 2, 3]lst2 = [4, 5, 6]lst3 = [7, 8, 9]# 序列化写入文件with open('pickle.txt', 'wb') as fp:    pickle.dump(lst1, fp)    pickle.dump(lst2, fp)    pickle.dump(lst3, fp)# 读取文件反序列化with open('pickle.txt', 'rb') as fp:    data1 = pickle.load(fp)  # [1, 2, 3]    print(data1)    data2 = pickle.load(fp)  # [4, 5, 6]    print(data2)    data3 = pickle.load(fp)  # [7, 8, 9]    print(data3)# 尝试先逐行读取,再反序列化with open('pickle.txt', 'rb') as fp:    datum = fp.readlines()    print(len(datum))  # 1        for data in datum:        data = pickle.loads(data)        print(data)  # [1, 2, 3]   # 只能读出一个

    可以看到 pickle.load 将数据都读出来了,这是因为 pickle.dump 在写入数据的时候在每条数据后都加上了一个标记(有些人解释说是换行,但是文件中并没有换行,逐行使用 fp.readlines 逐行读取的时候也只能获取一条,但是在文件中所有的数据都是在同一行的,我也不太懂了(无奈)),然后 pickle.load 每次就只会读一条数据,从IO指针读到每条数据后的那个标记为止,所以,pickle 可以连续的 load

    怎么解决json的这个问题?

    其实上面的这个问题,我个人认为是一种不规范的操作。因为 json.load 会一次性的读取整个文件中的内容,你却在一个文件中写入了不止一条的数据,那么在反序列化的时候当然会报错了。所以我认为:

    json的主要作用多语言之前的数据传递和数据存储,每个JSON文件中最好只储存一条完整的数据。

    但是我就想在一个json文件中存多个数据呢?

    其实思路很简单,关键就是读取文件然后反序列化的时候,必须是一条数据、一条数据的反序列化,类似如下:

    import json# 序列化数据lst1 = [1, 2, 3]lst2 = [4, 5, 6]lst3 = [7, 8, 9]# 序列化写入文件,每写入一条数据插一个换行with open('test.json', 'w', encoding='UTF-8') as fp:    json.dump(lst1, fp)    fp.write('\n')    json.dump(lst2, fp)    fp.write('\n')    json.dump(lst3, fp)# 读取文件反序列化(逐行读取数据,然后反序列化)with open('test.json', 'r', encoding='UTF-8') as fp:    datum = fp.readlines()    print(len(datum))  # 3    for data in datum:        data = json.loads(data)        print(data)  # [1, 2, 3]                     # [4, 5, 6]                     # [7, 8, 9]

    pickle和json的区别总结

    json序列化后的数据为字符串,pickle序列化后的数据为字节流;

    json支持八种数据类型(int、float、bool、str、list、tuple、dict、None),pickle支持python的一切数据类型;

    json一般用于多语言间的数据交流,pickle一般用于python之间数据交流。

    到此,相信大家对“Python序列化模块之pickle与json怎么使用”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

    --结束END--

    本文标题: Python序列化模块之pickle与json怎么使用

    本文链接: https://www.lsjlt.com/news/330149.html(转载时请注明来源链接)

    有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

    本篇文章演示代码以及资料文档资料下载

    下载Word文档到电脑,方便收藏和打印~

    下载Word文档
    猜你喜欢
    • Python序列化模块之pickle与json怎么使用
      本篇内容主要讲解“Python序列化模块之pickle与json怎么使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Python序列化模块之pickle与json怎么使用”吧!序列化模块imp...
      99+
      2023-06-30
    • Python序列化模块JSON与Pickle
      序列化把对象(变量)从内存中变成可存储或传输的过程称之为序列化,在Python中叫pickling,在其他语言中也被称之为serialization,marshalling,flat...
      99+
      2022-11-11
    • Python序列化模块之pickle与json详解
      目录序列化模块序列化和反序列化使用场景dumps & loadsdump & loadJSON序列化模块使用场景支持的数据类型JSON和pickle的区别序列化函数j...
      99+
      2022-11-11
    • Python数据序列化之pickle模块
      目录1将Python数据存储为本地文件①存储过程②加载过程2将Python数据存储为程序的一部分①存储过程②加载过程前言: 在英语中 pickle 名词是泡菜,动词是腌渍的意思。可以...
      99+
      2022-11-13
    • PythonJson与pickle模块序列化使用介绍
      用于序列化的两个模块 json,用于字符串 和 python数据类型间进行转换pickle,用于python特有的类型 和 python的数据类型间进行转换 Json模块提供了四个功...
      99+
      2022-11-11
    • Python数据序列化的pickle模块怎么用
      这篇文章主要介绍了Python数据序列化的pickle模块怎么用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Python数据序列化的pickle模块怎么用文章都会有所收获,下面我们一起来看看吧。前言:在英语中...
      99+
      2023-06-29
    • Python 对象序列化与反序列化之pickle json详细解析
      目录引言picklejson尾语引言 将对象的状态信息转换为可以存储或传输的形式的过程叫作序列化 类似地从序列化后的数据转换成相对应的对象叫作 反序列化 本文介绍 Python 将对...
      99+
      2022-11-12
    • 如何使用Python中的pickle模块进行对象序列化
      如何使用Python中的pickle模块进行对象序列化概述:在Python编程中,我们经常需要将数据保存到文件或通过网络传输。而对象序列化是一种将对象转化为可存储或传输的格式的过程,而pickle模块正是Python中一种常用的序列化模块。...
      99+
      2023-10-22
      Python pickle 对象序列化
    • 如何使用Python中的pickle和JSON进行对象序列化和反序列化
      如何使用Python中的pickle和JSON进行对象序列化和反序列化Python是一种简单而强大的编程语言,其内置了许多有用的库和模块,使开发人员能够快速进行各种任务。其中,pickle和JSON是两个常用的模块,用于对象序列化和反序列化...
      99+
      2023-10-22
      序列化 JSON pickle
    • JavaScript中怎么用JSON来序列化与反序列化
      小编给大家分享一下JavaScript中怎么用JSON来序列化与反序列化,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!用JSON...
      99+
      2022-10-19
    • Python JSON模块怎么使用
      本篇内容主要讲解“Python JSON模块怎么使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Python JSON模块怎么使用”吧!1.dumps( )将Python数...
      99+
      2023-06-25
    • python标准库模块之json库怎么使用
      今天小编给大家分享一下python标准库模块之json库怎么使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。前言json,...
      99+
      2023-07-02
    • python的json模块怎么使用
      这篇文章主要介绍“python的json模块怎么使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“python的json模块怎么使用”文章能帮助大家解决问题。一、概述推荐使用参考网站: json在p...
      99+
      2023-06-30
    • 怎么在python中使用序列化与反序列化
      这篇文章将为大家详细讲解有关怎么在python中使用序列化与反序列化,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。python有哪些常用库python常用的库:1.requesuts;2.s...
      99+
      2023-06-14
    • Golang中Json的序列化和反序列化怎么使用
      这篇文章主要介绍“Golang中Json的序列化和反序列化怎么使用”,在日常操作中,相信很多人在Golang中Json的序列化和反序列化怎么使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Golang中Js...
      99+
      2023-06-30
    • Python常用标准库之os模块与shutil模块怎么使用
      本文小编为大家详细介绍“Python常用标准库之os模块与shutil模块怎么使用”,内容详细,步骤清晰,细节处理妥当,希望这篇“Python常用标准库之os模块与shutil模块怎么使用”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入...
      99+
      2023-06-30
    • Python time模块之时间戳与结构化时间怎么使用
      本篇内容介绍了“Python time模块之时间戳与结构化时间怎么使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!导入相关库im...
      99+
      2023-07-02
    • Python之datetime模块怎么使用
      这篇文章主要讲解了“Python之datetime模块怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Python之datetime模块怎么使用”吧!1、日期时间对象日期时间对象是指具...
      99+
      2023-07-02
    • os模块与fnmatch模块怎么在python中使用
      本篇文章为大家展示了 os模块与fnmatch模块怎么在python中使用,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。python可以做什么Python是一种编程语言,内置了许多有效的工具,Pyt...
      99+
      2023-06-08
    • Python基础之模块怎么使用
      这篇文章主要介绍“Python基础之模块怎么使用”,在日常操作中,相信很多人在Python基础之模块怎么使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Python基础之模块怎么使用”的疑惑有所帮助!接下来...
      99+
      2023-07-06
    软考高级职称资格查询
    编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
    • 官方手机版

    • 微信公众号

    • 商务合作