python常用模块之shelve模块

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

我们在上面讲json、pickle模块的时候,说过都不能dump都多次,那么是真的吗?当然不是的, shelve模块就可以dump多次,shelve模块其实就是封装了pickle模块,并且顺序不会乱,因为shelve模块是k,v结构,给dump的数据指定一个名字,下次用这个名字就可以load回来。

序列化:

此模块的操作在linux系统下讲解

#!/usr/bin/python

import shelve

f = shelve.open("shelve_test")  # 使用shelve模块打开一个文件

names = ["li","xiao","rain"]
info = {"name":"li","age":22} f['names'] = names # 持久化列表
f['info_dir'] = info # 持久化字典 f.close()

shelve模块的操作:

# 在linux系统下,ipython3
In [1]: import shelve In [2]: f = shelve.open("shelve_test") # 此时的f就相当于是一个文件对象,即可以像字典样操作 In [3]: f.get('names')
Out[3]: ['li', 'xiao', 'rain'] In [4]: f.get('info_dir')
Out[4]: {'name': 'li', 'age': 22} In [5]: f.keys()
Out[5]: KeysView(<shelve.DbfilenameShelf object at 0x7f6a43269198>) # 是一个列表 In [6]: list(f.keys())
Out[6]: ['names', 'info_dir'] # 列表中存了两个持久化的k In [7]: list(f.items())
Out[7]: [('names', ['li', 'xiao', 'rain']), ('info_dir', {'name': 'li', 'age': 22})] # 删除
In [8]: del f['names'] # 删除持久化的k In [9]: f.close() # 关闭文件 In [10]: f = shelve.open("shelve_test") # 重新打开文件 In [12]: f.get('names') # 无任何输出 # 增加
In [13]: f['scores'] = [1,2,3,4,"rain"] # In [14]: f.close() In [15]: f = shelve.open("shelve_test") In [16]: f.get('scores')
Out[16]: [1, 2, 3, 4, 'rain'] # 修改,相当于是重新赋值
In [17]: f['scores']
Out[17]: [1, 2, 3, 4, 'rain'] In [18]: f['scores'] = [1,2,3,4,5] In [19]: f.close() In [20]: f = shelve.open("shelve_test") In [24]: f['scores']
Out[24]: [1, 2, 3, 4, 5]

反序列化:

#!/usr/bin/python

import shelve

d = shelve.open('shelve_test')

# print(d['names'])  # 因为在之前的操作中已经删除了这个
print(d['info_dir']) d.close()

输出结果为:

root@DESKTOP-G4V06P4:~/codes# python3 反序列化.py
{'age': 22, 'name': 'li'}
05-11 16:57
查看更多