python模块之shelve

本文深入讲解了Python中shelve模块的使用方法,包括如何利用该模块进行数据的序列化和反序列化,以及如何持久化复杂的数据结构如列表和字典。文章还提供了详细的代码示例,展示了shelve模块相较于pickle和json的优势。

shelve模块是一个简单的k,v将内存数据通过文件持久化的模块,可以持久化任何pickle可支持的python数据格式

shelve对pickle进行了封装,允许你dump多次,并且顺序不会乱。所以,能用shevel就用shevel,不能用就用pickle,pickle不能用再用json。

 

序列化:

import shelve

f = shelve.open('shelve_test')  # 打开一个文件

names = ["alex", "rain", "test"]
info = {'name':'alex','age':22}

f["names"] = names  # 持久化列表
f['info_dic'] = info

f.close()

反序列化:

import shelve

d = shelve.open('shelve_test')  # 打开一个文件

print(d['names'])
print(d['info_dic'])

#del d['test'] #还可以删除

 

代码示例:

# 对pickle进行了封装,允许你dump多次,并且顺序不会乱。

import shelve


f = shelve.open('shevel_test')  # 打开一个文件

info = {'name': 'alex', 'age': 22}
names = ['alex', 'rain', 'test']

f['names'] = names
f['info_dic'] = info

f.close()  # 也是存的一推乱码

with shelve.open('shevel_test') as f:
    print(f)  # <shelve.DbfilenameShelf object at 0x1032374a8>
    print(f.keys())  # KeysView(<shelve.DbfilenameShelf object at 0x101f37400>)
    print(list(f.keys()))  # ['names', 'info_dic']
    print(f.items())  # ItemsView(<shelve.DbfilenameShelf object at 0x101f37438>)
    print(f.get('names'))  # ['alex', 'rain', 'test']
    print(f.get('info_dic'))  # {'name': 'alex', 'age': 22}
    f['names'] = ['Rain', 'Ann', 'Jack'] # ['Rain', 'Ann', 'Jack']
    print(f.get('names'))

 

转载于:https://www.cnblogs.com/lshedward/p/10003532.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值