python|浅谈Python中的pickle模块

简介: python|浅谈Python中的pickle模块

Pickle模块的作用

Pickle模块用于将python对象序列化为字节流,可存储在文件或数据库中,也可同通过网络进行传输。使用反序列化(Unpickle)可以将生成的字节流转换回python对象。“Pickling”是将Python对象层次结构转换为字节流的过程,“unpickling”是反向操作,从而将字节流(来自二进制文件或类似字节的对象)转换回对象层次结构。酸洗(或去除)也可称为“序列化”,“编组”,不要将其与marshal模块混淆或“扁平化”; 但是,为了避免混淆,这里使用的术语是“酸洗”和“破坏”。

什么叫序列化?

把对象在内存中的结构转换成便于存储或传输的二进制或文本格式,而且以后可以在同一个系统或不同的系统中重建对象的副本。pickle模块能把任何Python对象序列化成二进制格式。

函数的运用

Pickle模块中dump()函数与load()函数的运用

pickle模块提供以下常量:

pickle.HIGHEST_PROTOCOL

整数,可用的最高协议版本。该值可以作为协议值传递给函数dump()和dumps()以及pickler构造函数。

pickle.DEFAULT_PROTOCOL

一个整数,用于酸洗的默认协议版本。可能小于最高协议。目前默认的协议是3,这是为python 3设计的新协议。

pickle模块提供以下功能,使酸洗过程更加方便:

pickle.dumpobjfileprotocol = None*fix_imports = True

objpickle d表示写入打开的文件对象文件。这相当于。 Pickler(file, protocol).dump(obj)

可选的协议参数,一个整数,告诉pickler使用给定的协议; 支持的协议是0HIGHEST_PROTOCOL。如果未指定,则默认为DEFAULT_PROTOCOL。如果指定了负数,HIGHEST_PROTOCOL则选择。

文件参数必须有一个接受单字节参数的write()方法。因此,它可以是一个为二进制写入而打开的磁盘上文件、一个IO.Bytesio实例或满足此接口的任何其他自定义对象。

如果fix_导入为真,且协议小于3pickle将尝试将新的python 3名称映射到python 2中使用的旧模块名称,以便pickle数据流可以用python 2读取。

pickle.dumpsobjprotocol =None*fix_imports = True

将对象的pickled表示作为bytes对象返回,而不是将其写入文件。

arguments协议和fix_导入的含义与dump()中的含义相同。

 

pickle.loadfile*fix_imports = Trueencoding =ASCII”,errors =strict

从打开的文件对象文件中读取pickled对象表示,并返回其中指定的重新构建的对象层次结构。这相当于unpicklerfile.load()。

自动检测pickle的协议版本,因此不需要协议参数。超过pickled对象表示形式的字节将被忽略。

参数文件必须有两个方法,一个采用整数参数的read()方法和一个不需要参数的readline()方法。两种方法都应返回字节。因此,文件可以是为二进制读取而打开的磁盘上文件、IO.Bytesio对象或满足此接口的任何其他自定义对象。

可选关键字参数包括fix_导入、编码和错误,这些参数用于控制由python 2生成的pickle流的兼容性支持。如果fix_importstruepickle将尝试将旧的python 2名称映射到python 3中使用的新名称。编码和错误告诉pickle如何解码由python 2处理的8位字符串实例;它们分别默认为'ascii''strict'。编码可以是“字节”,以将这些8位字符串实例读取为字节对象。需要使用encoding='latin1'来取消拾取由python 2处理的numpy数组和date time、日期和时间实例。

pickle.loadsbytes_object*fix_imports = Trueencoding =ASCII”,errors =strict

bytes对象读取pickled对象层次结构,并返回其中指定的重新构建的对象层次结构。

自动检测pickle的协议版本,因此不需要协议参数。超过pickled对象表示形式的字节将被忽略。

可选关键字参数包括fix_导入、编码和错误,这些参数用于控制由python 2生成的pickle流的兼容性支持。如果fix_importstruepickle将尝试将旧的python 2名称映射到python 3中使用的新名称。编码和错误告诉pickle如何解码由python 2处理的8位字符串实例;它们分别默认为'ascii''strict'。编码可以是“字节”,以将这些8位字符串实例读取为字节对象。需要使用encoding='latin1'来取消拾取由python 2处理的numpy数组和date time、日期和时间实例。


目录
相关文章
|
8天前
|
Python
在Python中,可以使用内置的`re`模块来处理正则表达式
在Python中,可以使用内置的`re`模块来处理正则表达式
20 5
|
18天前
|
Java 程序员 开发者
Python的gc模块
Python的gc模块
|
21天前
|
数据采集 Web App开发 JavaScript
python-selenium模块详解!!!
Selenium 是一个强大的自动化测试工具,支持 Python 调用浏览器进行网页抓取。本文介绍了 Selenium 的安装、基本使用、元素定位、高级操作等内容。主要内容包括:发送请求、加载网页、元素定位、处理 Cookie、无头浏览器设置、页面等待、窗口和 iframe 切换等。通过示例代码帮助读者快速掌握 Selenium 的核心功能。
63 5
|
22天前
|
Python
SciPy 教程 之 SciPy 模块列表 13
SciPy教程之SciPy模块列表13:单位类型。常量模块包含多种单位,如公制、二进制(字节)、质量、角度、时间、长度、压强、体积、速度、温度、能量、功率和力学单位。示例代码展示了如何使用`constants`模块获取零摄氏度对应的开尔文值(273.15)和华氏度与摄氏度的转换系数(0.5556)。
17 1
|
23天前
|
XML 前端开发 数据格式
超级详细的python中bs4模块详解
Beautiful Soup 是一个用于从网页中抓取数据的 Python 库,提供了简单易用的函数来处理导航、搜索和修改分析树。支持多种解析器,如 Python 标准库中的 HTML 解析器和更强大的 lxml 解析器。通过简单的代码即可实现复杂的数据抓取任务。本文介绍了 Beautiful Soup 的安装、基本使用、对象类型、文档树遍历和搜索方法,以及 CSS 选择器的使用。
53 1
|
20天前
|
Python
SciPy 教程 之 SciPy 模块列表 16
SciPy教程之SciPy模块列表16 - 单位类型。常量模块包含多种单位,如公制、质量、角度、时间、长度、压强、体积、速度、温度、能量、功率和力学单位。示例代码展示了力学单位的使用,如牛顿、磅力和千克力等。
15 0
|
21天前
|
JavaScript Python
SciPy 教程 之 SciPy 模块列表 15
SciPy 教程之 SciPy 模块列表 15 - 功率单位。常量模块包含多种单位,如公制、质量、时间等。功率单位中,1 瓦特定义为 1 焦耳/秒,表示每秒转换或耗散的能量速率。示例代码展示了如何使用 `constants` 模块获取马力值(745.6998715822701)。
15 0
|
21天前
|
JavaScript Python
SciPy 教程 之 SciPy 模块列表 15
SciPy教程之SciPy模块列表15:单位类型。常量模块包含多种单位,如公制、质量、角度、时间、长度、压强、体积、速度、温度、能量、功率和力学单位。功率单位以瓦特(W)表示,1W=1J/s。示例代码展示了如何使用`constants`模块获取马力(hp)的值,结果为745.6998715822701。
16 0
|
22天前
|
Python
SciPy 教程 之 SciPy 模块列表 13
SciPy 教程之 SciPy 模块列表 13 - 单位类型。常量模块包含多种单位:公制、二进制(字节)、质量、角度、时间、长度、压强、体积、速度、温度、能量、功率和力学单位。示例:`constants.zero_Celsius` 返回 273.15 开尔文,`constants.degree_Fahrenheit` 返回 0.5555555555555556。
14 0
|
23天前
|
Python
SciPy 教程 之 SciPy 模块列表 11
SciPy教程之SciPy模块列表11:单位类型。常量模块包含公制单位、质量单位、角度换算、时间单位、长度单位、压强单位、体积单位、速度单位、温度单位、能量单位、功率单位、力学单位等。体积单位示例展示了不同体积单位的换算,如升、加仑、流体盎司、桶等。
18 0