如何在Python中实现持久化对象?

如何在python中实现持久化对象?

要在Python中实现持久化对象,请使用以下库。

上架泡菜

搁置模块

“架子”是一个持久的、类似字典的对象。与“dbm”数据库的区别在于,架子中的值(不是键!)本质上可以是任意 Python 对象 – pickle 模块可以处理的任何对象。这包括大多数类实例、递归数据类型以及包含大量共享子对象的对象。

它有一些关键方法 –

shelve.open() – 打开持久字典。指定的文件名是基础数据库的基本文件名。副作用是,文件名中可能会添加扩展名,并且可能会创建多个文件。默认情况下,底层数据库文件以读写方式打开。

立即学习“Python免费学习笔记(深入)”;

shelve.sync() − 如果使用writeback设置为True打开了shelf,则将缓存中的所有条目写回。如果可行,还会清空缓存并将持久字典与磁盘上的数据同步。当使用close()关闭shelf时,会自动调用此方法。

shelve.close() − 同步并关闭持久化字典对象。

pickle 模块

pickle 模块实现了用于序列化和反序列化 Python 对象的二进制协议结构。

Pickling 是将Python对象层次结构转换为字节的过程流。要序列化一个对象层次结构,只需调用dumps()函数。

Unpickling是逆操作。从二进制文件或类似字节对象的字节流中解析出来的将其转换回对象层次结构。要反序列化数据流,您调用loads()函数功能。

Pickle 模块功能

以下是pickle模块提供的函数。

pickle.dump() – 将对象的pickle表示写入打开的文件对象文件中。

pickle.dumps() − 返回对象的pickle表示作为一个字节对象,而不是将其写入文件中。

pickle.load() – 从打开的文件对象文件中读取对象的pickled表示。

pickle.loads() – 返回 pickled 表示数据的重构对象层次结构对象的

示例

首先,导入pickle模块 –

import pickle

我们已经创建了以下输入以进行pickle。

my_data = { 'BMW', 'Audi', 'Toyota', 'Benz'}

demo.pickle 文件已创建。这个相同的 .pickle 文件是用上面的列表进行腌制的。

with open("demo.pickle","wb") as file_handle:   pickle.dump(my_data, file_handle, pickle.HIGHEST_PROTOCOL)

现在,取消上面的 pickled 文件并获取输入值。

with open("demo.pickle","rb") as file_handle:   res = pickle.load(file_handle)   print(res_data)

现在让我们看看完整的示例。

import pickle# Input Datamy_data = { 'BMW', 'Audi', 'Toyota', 'Benz'}# Pickle the inputwith open("demo.pickle","wb") as file_handle:   pickle.dump(my_data, file_handle, pickle.HIGHEST_PROTOCOL)# Unpickle the above pickled filewith open("demo.pickle","rb") as file_handle:   res = pickle.load(file_handle)   print(my_data) # display the output

输出

set(['Benz', 'Toyota', 'BMW', 'Audi'])

以上就是如何在Python中实现持久化对象?的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1342772.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月13日 05:53:20
下一篇 2025年12月13日 05:53:33

相关推荐

发表回复

登录后才能评论
关注微信