一、定义:
Shelve是对象持久化保存方法,将对象保存到文件里,默认的存储文件是二进制的。可作为一个简单的数据存储方案。
二、用法:
使用open函数获取一个shelf对象,然后对数据进行操作,在完成工作、并将内存存储到磁盘中,最后调用close函数变回将数据写入文件。
三、使用方法:
1、shelve.open(filename, flag=‘c’,protocol=None,writeback=False)
创建或打开一个shelve对象。shelve默认打开方式支持同时读写操作。
filename:关联的文件路径
flag :
- ‘r’ :以只读模式打开一个已经存在的数据存储文件
- ‘w’ :以读写模式打开一个已经存在的数据存储文件
- ‘c’ :(默认)以读写模式打开一个数据存储文件,如果不存在则创建
- ‘n’ :总是以读写模式打开并且创建一个新的空数据存储文件
protocol:表示序列化数据所使用的协议,默认为 None(pickle v3)
writebake:表示是否开启回写功能
2、shelve.close()
同步并关闭shelve对象。
四、writeback参数:
writeback:默认为False。当设置为True以后,shelf将会将所有从DB中读取的对象存放到一个内存缓存。当我们close()打开的shelf的时候,缓存中所有的对象会被重新写入DB。
writeback优点&缺点:
优点:减少了我们出错的概率,并且让对象的持久化对用户更加的透明了;
缺点:首先,使用writeback以后,shelf在open()的时候会增加额外的内存消耗,并且当DB在close()的时候会将缓存中的每一个对象都写入到DB,这也会带来额外的等待时间。因为shelve没有办法知道缓存中哪些对象修改了,哪些对象没有修改,因此所有的对象都会被写入。
前提:writeback=Trued
#1.创建shelf对象,直接使用open函数即可,test_shelf.txt自动创建
import shelve
s = shelve.open('test_shelf.txt')
try:
s['kk'] = {'int':10,'float':9.5,'String':'Sample data'}
s['MM'] = {1,2,3}
finally:
s.close()
#2.如果需要再次访问这个shelf,只需再次shelve.open()即可。
import shelve
try:
s = shelve.open('test_shelf.db')
value = s['kk']
print(value)
finally:
s.close()
运行结果:{‘String’: ‘Sample data’, ‘int’: 10, ‘float’: 9.5}
# database.py 简单的数据库
import sys, shelve
def store_person(db):
"""
让用户输入数据并将其保存到shelf对象中
"""
pid = input('Enter unique ID number:')
person = {}
person['name'] = input('Enter name:')
person['age'] = input('Enter age:')
person['phone'] = input('Enter phone number:')
db[pid] = person
def lookup_person(db):
"""
让用户输入ID和所需的字段,并从shelf对象中获取相应的数据
"""
pid = input('Enter ID number:')
field = input('What would you like to know? (name,age,phone)')
#删除空格、转成小写
field = field.strip().lower()
#capitalize方法返回一个首字母大写的字符串
print(field.capitalize() + ':',db[pid][field])
def print_help():
print('The available commands are:')
print('store : Stores information about a person')
print('lookup : Looks up a person from ID number')
print('quit : Save changes and exit')
print('? : Prints this message')
def enter_command():
cmd = input('Enter command(? for help): ')
cmd = cmd.strip().lower()
return cmd
def main():
database = shelve.open('database.dat')
try:
while True:
cmd = enter_command()
if cmd == 'store':
store_person(database)
elif cmd == 'lookup':
lookup_person(database)
elif cmd == '?':
print_help()
elif cmd == 'quit':
return
finally:
database.close()
if name == '__main__':
main()