序列化shelve模块

1.shelve对pickle进行封装,所以shelve也只能在python里使用。

shelve可以进行多次dump而且顺序不会乱。

 

import shelve

f = shelve.open('shelve_test')    #打开文件方式和json,pickle不同。

names = ['li','xiao','xiao','ali','lucas']
dicts = {'lucy':1,'liming':2,'casio':3}

f["first"] = names          #把文件当成一个字典,括号里的是字典的key,括号外面的数据类型是字典的value。
f["second"] = dicts

f.close()

下面在终端对文件进行修改,删除,增加等操作。

 

>>> import shelve
>>> f = shelve.open("shelve_test")
>>> list(f.items())
[('first', ['li', 'xiao', 'xiao', 'ali', 'lucas']), ('second', {'lucy': 1, 'liming': 2, 'casio': 3}), ('source', [1, 2, 5, 6, 7, 8, 9, 0])]
>>> f["source"]
[1, 2, 5, 6, 7, 8, 9, 0]                  #注意:不能直接对value里面的值进行修改,只能给key进行重新赋值来达到修改。
>>> f.get("source")
[1, 2, 5, 6, 7, 8, 9, 0]
>>> f["source"] = [1,2,3,4,6,8,9]
>>> list(f.items())
[('first', ['li', 'xiao', 'xiao', 'ali', 'lucas']), ('second', {'lucy': 1, 'liming': 2, 'casio': 3}), ('source', [1, 2, 3, 4, 6, 8, 9])]
>>> del f["source"]
>>> list(f.items())
[('first', ['li', 'xiao', 'xiao', 'ali', 'lucas']), ('second', {'lucy': 1, 'liming': 2, 'casio': 3})]
>>> f["add_1"] = [1,1,1,1,12,3,4]
>>> list(f.items())
[('first', ['li', 'xiao', 'xiao', 'ali', 'lucas']), ('second', {'lucy': 1, 'liming': 2, 'casio': 3}), ('add_1', [1, 1, 1, 1, 12, 3, 4])]

  

shelve对比json,pickle的优缺点

shelve可以多次dump,并且能够通过key值返回需要的数据类型,很方便,不会乱。

shelve比pickle常用,但是json可以跨语言,shelve不可以。  

转载于:https://www.cnblogs.com/Roc-Atlantis/p/8863062.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值