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、日期和时间实例。


目录
相关文章
|
1天前
|
JSON 数据格式 Python
Python标准库中包含了json模块,可以帮助你轻松处理JSON数据
【4月更文挑战第30天】Python的json模块简化了JSON数据与Python对象之间的转换。使用`json.dumps()`可将字典转为JSON字符串,如`{"name": "John", "age": 30, "city": "New York"}`,而`json.loads()`则能将JSON字符串转回字典。通过`json.load()`从文件读取JSON数据,`json.dump()`则用于将数据写入文件。
6 1
|
5天前
|
人工智能 安全 Java
Python 多线程编程实战:threading 模块的最佳实践
Python 多线程编程实战:threading 模块的最佳实践
122 5
|
5天前
|
人工智能 数据库 开发者
Python中的atexit模块:优雅地处理程序退出
Python中的atexit模块:优雅地处理程序退出
8 3
|
8天前
|
存储 开发者 Python
Python中的argparse模块:命令行参数解析的利器
Python中的argparse模块:命令行参数解析的利器
16 2
|
8天前
|
开发者 Python
Python的os模块详解
Python的os模块详解
16 0
|
11天前
|
数据挖掘 API 数据安全/隐私保护
python请求模块requests如何添加代理ip
python请求模块requests如何添加代理ip
|
13天前
|
测试技术 Python
Python 有趣的模块之pynupt——通过pynput控制鼠标和键盘
Python 有趣的模块之pynupt——通过pynput控制鼠标和键盘
|
13天前
|
Serverless 开发者 Python
《Python 简易速速上手小册》第3章:Python 的函数和模块(2024 最新版)
《Python 简易速速上手小册》第3章:Python 的函数和模块(2024 最新版)
42 1
|
14天前
|
开发者 Python
Python中的并发编程:使用asyncio模块实现异步任务
传统的Python编程中,使用多线程或多进程进行并发操作时,常常会面临性能瓶颈和资源竞争的问题。而随着Python 3.5版本的引入,asyncio模块为开发者提供了一种基于协程的异步编程方式。本文将介绍如何使用asyncio模块实现异步任务,提高Python程序的并发处理能力。
|
14天前
|
测试技术 Python
Python 的自动化测试:如何使用 Python 的 unittest 模块进行测试?
在Python中进行自动化测试可利用`unittest`模块。以下是一个简单的示例,展示了如何编写测试用例
10 0