python pickle模块安装_python pickle 模块的使用以及2种典型报错处理

用于序列化的两个模块

json:用于字符串和Python数据类型间进行转换

pickle: 用于python特有的类型和python的数据类型间进行转换

json提供四个功能:dumps,dump,loads,load

pickle提供四个功能:dumps,dump,loads,load

pickle可以存储什么类型的数据呢?

所有python支持的原生类型:布尔值,整数,浮点数,复数,字符串,字节,None。

由任何原生类型组成的列表,元组,字典和集合。

函数,类,类的实例

pickle模块中常用的方法有:pickle.dump(obj, file, protocol=None,)

必填参数obj表示将要封装的对象

必填参数file表示obj要写入的文件对象,file必须以二进制可写模式打开,即“wb”

可选参数protocol表示告知pickler使用的协议,支持的协议有0,1,2,3,4 , 默认的协议是添加在Python 3中的协议3。

pickle.load(file,*,fix_imports=True, encoding="ASCII", errors="strict")

必填参数file必须以二进制可读模式打开,即“rb”,其他都为可选参数

pickle.dumps(obj, protocol=None):以字节对象形式返回封装的对象,不需要写入文件中

pickle.loads(bytes_object): 从字节对象中读取被封装的对象,并返回

简单实用示例

# dumps功能

import pickle

data = ['aa', 'bb', 'cc']

# dumps 将数据通过特殊的形式转换为只有python语言认识的字符串

p_str = pickle.dumps(data)

print(p_str)

# loads功能

# loads 将pickle数据转换为python的数据结构

ret = pickle.loads(p_str)

print(ret)

# dump功能

# dump 将数据通过特殊的形式转换为只有python语言认识的字符串,并写入文件

with open('data.pkl', 'wb') as f:

pickle.dump(data, f)

# load功能

# load 从数据文件中读取数据,并转换为python的数据结构

with open('data.pkl', 'rb') as f:

data = pickle.load(f)

#输出结果

b'\x80\x03]q\x00(X\x02\x00\x00\x00aaq\x01X\x02\x00\x00\x00bbq\x02X\x02\x00\x00\x00ccq\x03e.'

['aa', 'bb', 'cc']

注意 !注意!!注意!!!重要的事情说三遍

如果要保存的信息是原生数据类型时,以上实用完全可以满足要求,

一、只能加载一次:EOFError: Ran out of input

报错原因,数据提前解析

二、保存的数据为类对象时需要注意路径问题:

实用时错误产生原因,

用pickledumps()封装类对象,并将数据保存至阿里云,然后用在另一个服务解析数据,导致我数据能拿到,但不能正确解析出类对象,后来发现是缺少了对应的类对象,并且类对象要和打包时的类对象路径保持一致

pickle.dumps()或pickle.dump()封装时,会根据你所加载的类对象对数据进行对象化,同时也会把类对象的路径也打包进去,记录下它是根据那个目录下的哪个类进行封装的,同样解析时也要找到对应目录下的对应类进行解析还原

在同一个项目或文件中能完全使用,因为类对象路径没有变化

在另一个项目中加载pickle对象,错误信息如下:

ModuleNotFoundError: No module named 'pickle_test.model'

可以打印pickle信息进行确认:

可以看出是要还原成目录pickle_test.model下的Person对象类型,但是找不到,所以只需要把对应的目录和类还原回去即可

安装_pickle模块不需要单独操作,因为_picklePython的内置模块。_pickle模块用于序列化对象,即将对象转换成字节流以便存储或传输。在Python使用_pickle模块可以方便地将对象持久化保存到磁盘上,并在需要时将其读取出来恢复成原来的对象。 在使用Python 3时,默认已经自带_pickle模块,无需进行额外的下载和安装。可以直接在代码中通过`import pickle`来导入_pickle模块,然后使用_pickle模块的相关函数进行对象的序列化和反序列化操作。 常用的_pickle模块函数包括: - dumps(obj):将对象序列化为字节流 - loads(data):将字节流反序列化为对象 - dump(obj, file):将对象序列化并保存到文件中 - load(file):从文件中读取字节流并将其反序列化为对象 在导入_pickle模块后,就可以使用上述函数进行对象的序列化和反序列化操作了。例如,可以使用dumps函数将对象转换成字节流并打印出来,然后使用loads函数将字节流转换回对象。 需要注意的是,使用_pickle模块进行对象的序列化和反序列化时,可能会存在一些安全风险,因为_pickle模块可以执行任意的Python代码。如果需要在不可信的环境下进行对象序列化和反序列化操作,建议使用更安全的序列化模块,如JSON模块。 总之,Python 3已经内置了_pickle模块,可以直接导入并使用相关函数进行对象的序列化和反序列化操作,无需额外的下载和安装
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值