python对象持久化的方法
- 更新时间:2021-08-08 09:36:37
- 编辑:蒲苑博
给网友们整理相关的编程文章,网友关明远根据主题投稿了本篇教程内容,涉及到Python相关内容,已被505网友关注,相关难点技巧可以阅读下方的电子资料。
参考资料
- Python网络爬虫实战 PDF 电子书 / 47.4 MB / 胡松涛 推荐度:
- Effective Python:编写高质量Python代码的90个有效方法(第2版) PDF 电子书 / 86 MB / 布雷特·斯拉特金 推荐度:
- Python Docker实战 PDF 电子书 / 2.9 MB / 萨蒂亚吉斯·巴哈 推荐度:
- Python网络数据采集 PDF 电子书 / 16.7 MB / 米切尔 推荐度:
- 预测分析建模:Python与R语言实现 PDF 电子书 / 79.4 MB / 托马斯 推荐度:
正文内容
《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