1、说明
pickle:任意python对象和字节串之间的序列化
dbm:实现一个可通过键访问的文件系统,以存储字符串
shelve:使用上述两个模块把python对象存储到一个文件中,即按键存储pickle处理后的对象并存储在dbm的文件中
2、实例
## pickle ## 将对象序列化到文件 f1 = open("pickle.db","wb+") pickle.dump(p1,f1) ## 这里不能一步到位,即open("pickle.db","wb+"),会导致pickle在读取的时候抛出EOFError: Ran out of input f1.close() ## 将对象序列化为字符串 string = pickle.dumps(p1) ## 从文件读取 f = open("pickle.db","rb") p = pickle.load(f) ## 从字符串读取 p_obj = pickle.loads(string) ## dbm ## 存储 db = dbm.open("dbm","c") db[k1] = v1 db.close() ## 读取 db = dbm.open("dbm","c") for key in db.keys(): print("key[%s] -- %s" % (key,db[key])) ## shelve import shelve db = shelve.open("persondb") ## filename for object in [p1,p2]: db[object.name] = objectdb.close() ## 必须关闭 ## 从db文件中读取 db = shelve.open("persondb") ## db拥有和字典相同的方法,区别在于shelve需要打开和关闭操作 for key in db.keys(): print("from db[%s]" % db[key])
本文教程操作环境:windows7系统、Python 3.9.1,DELL G3电脑。
苹果芯片加持下PyTorch如何利用GPU和NPU?
NumPy保存和加载数据时如何处理None值?
遇到Python读取Excel测试用例时出现“list index out of range”错误,可以按照以下步骤解决:检查Excel文件内容:确保Excel文件中的数据完整且格式正确。错误常见于尝试访问不存在的列表索引,因此确认每一行都有足够的数据。查看代码逻辑:检查读取Excel文件的代码,特别是涉及到列表索引的部分。确保你访问的索引在列表的有效范围内。例如,如果列表长度为5,索引只能从0到4。调试代码:在可能出错的地方添加打印语句或使用调试器,查看变量的值和列表的长度,确保你在正确的位置访问正确的
微信扫码后小窗口变空白?解决方法在这里!
TCP端口占用:服务端程序退出后,端口为何依然被占用且如何解决?
初学者 Python 项目:使用 OpenCV 和 Mediapipe 构建增强现实绘图应用程序