热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Python标准库概览:shelve模块的使用

当项目需要一个简单且高效的存储方案时,Python的shelve模块是一个不错的选择。本文将详细介绍如何利用shelve模块进行基本的数据持久化操作,包括如何打开数据库、进行数据的增删查改等。

shelve模块提供了类似字典的接口,用于存储任意Python对象。使用shelve模块时,仅需提供一个文件名即可开始存储数据。该模块最核心的功能是通过open函数创建或打开一个shelve数据库,返回一个Shelf对象。



注意事项:



  • 可以像操作普通字典一样对Shelf对象进行操作,但需要注意的是,所有的键必须是字符串类型。

  • 完成所有操作后,务必调用close方法来确保数据被正确地写入磁盘并释放资源。



从Python 2.4版本起,open函数新增了一个writeback参数,设置为True时,所有从shelf读取或赋值给shelf的数据结构都将保存在内存中(即缓存),并在shelf关闭时一次性写回到磁盘,这有助于减少频繁的磁盘I/O操作。



技术分享



参数说明:


shelve.open(filename, flag='c', protocol=None, writeback=False),其中filename为文件名,flag定义文件的打开模式,默认为'c',表示如果文件不存在则创建;protocol指定pickle协议版本;writeback控制是否启用缓存机制。



常见问题及解决方法:


在使用shelve进行列表操作时,如直接对列表元素进行修改,可能会遇到数据未更新的问题。这是因为shelve在进行列表操作时,默认情况下会创建一个副本进行修改,而不会立即更新原始数据。正确的做法是在修改后显式地将更改后的数据重新赋值给对应的键,例如:


import shelve

db = shelve.open('data.dat')
db['x'] = ['a', 'b', 'c']
temp = db['x']
temp.append('d')
db['x'] = temp
print(db['x']) # 输出: ['a', 'b', 'c', 'd']


示例应用:


下面是一个简单的个人信息管理系统,支持信息的录入和查询功能,并在添加信息时检查是否存在重复的ID号:


import sys, shelve

def store_person(db):
while True:
pid = input('请输入唯一的ID号: ')
if pid in db:
print('已存在相同的ID号')
else:
break
person = {}
person['name'] = input('请输入姓名: ')
person['age'] = input('请输入年龄: ')
person['phone'] = input('请输入电话号码: ')
db[pid] = person
print('信息添加成功!')

def lookup_person(db):
pid = input('请输入ID号: ')
field = input('您想了解什么信息?(name, age, phone, all): ').strip().lower()
if field == 'all':
for key, value in db[pid].items():
print(key, ':', value)
else:
print(field.capitalize(), ':', db[pid][field])

def print_help():
print('帮助信息')

def enter_command():
cmd = input('请输入命令(? 查看帮助): ').strip().lower()
return cmd

def main():
database = shelve.open('date.dat')
try:
while True:
cmd = enter_command()
if cmd == 's':
store_person(database)
elif cmd == 'l':
lookup_person(database)
elif cmd == '?':
print_help()
elif cmd == 'q':
break
finally:
database.close()
print('程序已终止')

if __name__ == '__main__':
main()

推荐阅读
  • 在Ubuntu 16.04中使用Anaconda安装TensorFlow
    本文详细介绍了如何在Ubuntu 16.04系统上通过Anaconda环境管理工具安装TensorFlow。首先,需要下载并安装Anaconda,然后配置环境变量以确保系统能够识别Anaconda命令。接着,创建一个特定的Python环境用于安装TensorFlow,并通过指定的镜像源加速安装过程。最后,通过一个简单的线性回归示例验证TensorFlow的安装是否成功。 ... [详细]
  • 列表是 Python 编程语言中最常用的数据结构之一,它类似于其他编程语言中的数组。本文将详细介绍 Python 3 中列表的基本操作和特性。 ... [详细]
  • 掌握数据库引擎存储过程与系统视图查询:DBA与BI开发者的必备技能
    本文介绍了如何利用数据库引擎存储过程及系统视图查询数据库结构和对象信息,为数据库管理员(DBA)和商业智能(BI)开发人员提供实用的基础知识。文章涵盖了一系列常用的SQL Server存储过程和系统视图,帮助读者快速获取数据库的相关信息。 ... [详细]
  • 本问题涉及对一个非负整数数组执行加一操作。数组以最高位数字在前的方式存储,每个数组元素仅包含一位数字。假设该整数没有前导零,除非该整数为0。 ... [详细]
  • 一年一度的“跳石头”竞赛即将拉开帷幕,赛事将在一条直线型的河流中举行,河流中散布着多个巨大的岩石。比赛的起点和终点已由组织方选定。在起点与终点之间,存在N个岩石(不包括起点和终点)。为了增加比赛的挑战性,组织方计划移除部分岩石,以使选手在比赛中的最小跳跃距离最大化。 ... [详细]
  • Java Set集合源码深度解析
    本文将深入探讨Java集合框架中的Set接口及其主要实现类HashSet、LinkedHashSet和TreeSet的源码实现,帮助读者理解这些集合类的工作原理及应用场景。 ... [详细]
  • FreeBSD作为Berkeley Software Distribution (BSD)的一个关键分支,其发展历程深刻影响了现代操作系统的设计。本文将探讨FreeBSD从早期版本到最新版本的技术进步及其对计算行业的贡献。 ... [详细]
  • 本周工作重点在于细化用户需求文档,同时深入学习了jQuery的操作技巧及其源码解析。通过阅读知乎上的高质量问答,获取了关于如何有效阅读和理解jQuery源码的专业建议。 ... [详细]
  • javascript  实例 静态 公共 私有
    传统javascript的原型对象和ts的类对比传统 ... [详细]
  • 本文详细介绍了printf函数中的常见格式化符号和转义字符,以及如何在实际编程中灵活运用这些符号进行格式化输出。 ... [详细]
  • 尽管大多数解决方案倾向于使用递归来解决数独问题,但递归方法并非总是最优选择。本文探讨了一种基于迭代的方法来求解数独,这种方法不仅避免了递归的局限性,还通过使用集合来高效管理空位及其可能的数字选项。此方法未采用剪枝或最小候选数优先策略,而是通过迭代遍历所有可能性来寻找解。 ... [详细]
  • 在理解了支付宝分布式事务服务DTS的基本原理后,您可能会好奇,如果在两阶段提交过程中发生故障(如断电或JVM崩溃),事务能否顺利完成?本文将探讨DTS如何确保事务的最终一致性,即使在异常情况下。 ... [详细]
  • 深入理解Kafka架构
    本文将详细介绍Kafka的内部工作机制,包括其工作流程、文件存储机制、生产者与消费者的具体实现,以及如何通过高效读写技术和Zookeeper支持来确保系统的高性能和稳定性。 ... [详细]
  • Mac系统下解决sh: ./configure: Permission denied错误的方法
    在Mac操作系统中,当尝试运行配置脚本时,可能会遇到权限被拒绝的错误提示。本文将详细解释这一问题的原因,并提供两种有效的解决方法。 ... [详细]
  • 第七次团队冲刺进展
    本次站立会议更新了项目进展,包括学生登录注册界面的初步实现和教师网页的设计优化。同时,我们对当前的任务进行了详细的讨论,并调整了后续的工作计划。 ... [详细]
author-avatar
Era_zhou
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有