python对象持久化的方法

  • 更新时间:2021-08-08 09:36:37
  • 编辑:蒲苑博
给网友们整理相关的编程文章,网友关明远根据主题投稿了本篇教程内容,涉及到Python相关内容,已被505网友关注,相关难点技巧可以阅读下方的电子资料。

参考资料

正文内容

《python对象持久化的方法》是一篇不错的Python文章,感觉很有用处,把错误代码改掉了,为了方便大家的阅读。

python对象持久化的方法

1、说明

pickle:任意python对象和字节串之间的序列化

dbm:实现一个可通过键访问的文件系统,以存储字符串

shelve:使用上述两个模块把python对象存储到一个文件中,即按键存储pickle处理后的对象并存储在dbm的文件中

2、实例

## pickle
## 将对象序列化到文件
f1 = open("pickle.db","wb+")
pickle.dump(p1,f1)  ## 这里不能一步到位,即open("pickle.db","wb+"),会导致pickle在读取的时候抛出EOFError: Ran out of input 
f1.close()
 
## 将对象序列化为字符串
string = pickle.dumps(p1)
 
## 从文件读取
f = open("pickle.db","rb")
p = pickle.load(f)
## 从字符串读取
p_obj = pickle.loads(string)
## dbm
## 存储
db = dbm.open("dbm","c")
db[k1] = v1
db.close()
## 读取
db = dbm.open("dbm","c")
for key in db.keys():    
print("key[%s] -- %s" % (key,db[key]))
## shelve
import shelve
db = shelve.open("persondb")    
## filename
for object in [p1,p2]:    
db[object.name] = objectdb.close()  
## 必须关闭
## 从db文件中读取
db = shelve.open("persondb")        ## db拥有和字典相同的方法,区别在于shelve需要打开和关闭操作
for key in db.keys():    
print("from db[%s]" % db[key])

以上就是python对象持久化的方法,希望对大家有所帮助。

本文教程操作环境:windows7系统、Python 3.9.1,DELL G3电脑。

相关教程

  • 浅析Python模块之间的相互引用问题

    这篇文章主要介绍了Python模块之间的相互引用问题,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

    发布时间:2021-05-02

  • python使用epoll实现服务端的方法

    今天小编就为大家分享一篇python使用epoll实现服务端的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

    发布时间:2019-06-03

用户留言