python shelve

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

1.shelve

#!/usr/bin/env python
#-*- coding:utf-8 –*-

import shelve
d = shelve.open("shelve_test")

l1=["a1"]
l2=["a2"]
l3=["a3"]

d["k1"] = l1
d["k2"] = l2
d["k3"] = l3

d.close()

>>> import shelve
>>> a = shelve.open("shelve_test")
>>> a.get("k1")
[‘a1‘]
>>> a.get("k2")
[‘a2‘]
>>> a.get("k3")
[‘a3‘]
>>> a.get("k1")
[‘a1‘]

2.pick

import pickle

l1=["a1"]
l2=["a2"]
l3=["a3"]

with open("pickle","wb") as f:
    pickle.dump(l1,f)
    pickle.dump(l2, f)
    pickle.dump(l3, f)

>>> import pickle
>>> f = open("pickle","rb")
>>> pickle.load(f)    #只能按顺序读取
[‘a1‘]
>>> pickle.load(f)
[‘a2‘]
>>> pickle.load(f)
[‘a3‘]
>>> pickle.load(f)
时间: 2024-08-11 07:35:22

python shelve的相关文章

python shelve模块

import shelve import datetime d = shelve.open('shelve_test') '''写入文件''' info = {'age': 22, 'job': 'IT'} name = ['Jack', 'Rose'] d['name'] = name d['info'] = info d['data'] = datetime.datetime.now() d.close() '''读取文件''' d = shelve.open('shelve_test')

python shelve 模块

一.简介 在python3中我们使用json或者pickle持久化数据, 能dump多次,但只能load一次,因为先前的数据已经被后面dump的数据覆盖掉了. 如果我们想要实现dump和load多次,可以使用shelve模块. shelve模块可以持久化所有pickle所支持的数据类型. 代码: #持久化数据 import shelve import datetime # info = {'name': 'bigberg', 'age': 22} # name = ['Apoll', 'Zous

Python代码样例列表

├─algorithm│       Python用户推荐系统曼哈顿算法实现.py│      NFA引擎,Python正则测试工具应用示例.py│      Python datetime计时程序的实现方法.py│      python du熊学斐波那契实现.py│      python lambda实现求素数的简短代码.py│      Python localtime()方法计算今天是一年中第几周.py│      Python math方法算24点代码详解.py│      Pyth

python开发模块基础:序列化模块json,pickle,shelve

一,为什么要序列化 # 将原本的字典.列表等内容转换成一个字符串的过程就叫做序列化'''比如,我们在python代码中计算的一个数据需要给另外一段程序使用,那我们怎么给?现在我们能想到的方法就是存在文件里,然后另一个python程序再从文件里读出来.但是我们都知道,对于文件来说是没有字典这个概念的,所以我们只能将数据转换成字典放到文件中.你一定会问,将字典转换成一个字符串很简单,就是str(dic)就可以办到了,为什么我们还要学习序列化模块呢?没错序列化的过程就是从dic 变成str(dic)的

Python基础(12)_python模块之sys模块、logging模块、序列化json模块、pickle模块、shelve模块

5.sys模块 sys.argv 命令行参数List,第一个元素是程序本身路径 sys.exit(n) 退出程序,正常退出时exit(0) sys.version 获取Python解释程序的版本信息 sys.maxint 最大的Int值 sys.path 返回模块的搜索路径,初始化时使用PYTHONPATH环境变量的值 sys.platform 返回操作系统平台名称 5.1 使用sys.argv进行登录判断,跳过 i/o阻塞 #使用sys.argv进行登录判断,跳过 i/o阻塞 import s

python序列化: json & pickle & shelve 模块

一.json & pickle & shelve 模块 json,用于字符串 和 python数据类型间进行转换pickle,用于python特有的类型 和 python的数据类型间进行转换Json模块提供了四个功能:dumps.dump.loads.loadpickle模块提供了四个功能:dumps.dump.loads.load json模块:下面通过一些示例来学习:首先我们来看json的dumps和loads方法 s1={"k1":"v1"}

python模块(shelve,xml,configparser,hashlib,logging)

1.1shelve模块 shelve 模块比pickle模块简单,只有一个open函数,返回类似字典对象,可读可写:key必须为字符串, 而值可以是python所支持的数据类型. shelve模块主要用来存储一个简单的数据, shelve最重要的函数是open,在调用它的时候,使用文件名作为参数,它会返回一个架子(shelf)对象,可以用它来存储类容. 1 f = shelve.open(r"shelve_test.txt") 2 # aa = {"stu1":{&

python的shelve模块

shelve shelve是一额简单的数据存储方案,他只有一个函数就是open(),这个函数接收一个参数就是文件名,并且文件名必须是.bat类型的.然后返回一个shelf对象,你可以用他来存储东西,就可以简单的把他当作一个字典,当你存储完毕的时候,就调用close函数来关闭 这个有一个潜在的小问题,如下: import shelve list = [1, 2, 3] she = shelve.open('test.dat') she['d'] = list she['d'].append('f'

python学习道路(day6note)(time &datetime,random,shutil,shelve,xml处理,configparser,hashlib,logging模块,re正则表达式)

1.tiim模块,因为方法较多我就写在code里面了,后面有注释 1 #!/usr/bin/env python 2 #_*_coding:utf-8_*_ 3 4 print("time".center(60,"-")) 5 print(time.asctime()) #返回字符串格式 外国的时间 6 #Fri Nov 18 11:25:08 2016 7 t = time.localtime() #本地时间 8 #print(t) #这是一个对象所以需要 9 p