Python实现命令行通讯录实例教程
作者:daisy 发布时间:2023-10-18 01:51:28
标签:Python,命令行,通讯录
1、实现目标
编写一个命令行通讯录程序,可以添加、查询、删除通讯录好友及电话
2、实现方法
创建一个类来表示一个人的信息。使用字典存储每个人的对象,名字作为键。
使用pickle模块永久地把这些对象存储下来。
使用字典内建的方法添加、删除修改人员信息。
3、思维导图
4、编写伪代码
# 1.创建字典用来存储通讯录信息
# 2.创建人员类,包含姓名、关系、电话三个属性
# 3.创建操作类,包含增加、查询、删除人员,退出,保存并退出五个方法
# 4.程序运行
# 5.判断通讯录文件是否存在
# 6.如果存在,将文件读取到personDictionary字典中
# 7.如果不存在,提示并创建
# 8.while循环等待读取指令
# 9.如果指令为addperson,添加通讯录人员
# 10.如果指令为delperson,删除通讯录人员
# 11.如果指令为search,查找通讯录人员
# 12.如果指令为quit,不保存退出程序
# 13.如果指令为sq,保存更改并退出程序
5、根据伪代码编写代码
import pickle as p
import os
# 1.创建字典用来存储通讯录信息
personDictionary= {'name':{'relationship':'','tel':''}}
relationshipList=['家人','朋友','同事']
# 2.创建人员类,包含姓名、关系、电话三个属性
class Person:
def __init__(self,name,relationship= relationshipList[1],tel='None'):
personDictionary[name]= {'relationship':relationship,'tel':tel}
# 3.创建操作类,包含增加、查询、删除人员,退出,保存并退出五个方法
class Operation:
def Addperson():
addname= input('请输入姓名:')
addrelationship= int(input('请选择分组(0:家人,1:朋友,2:同事):'))
addtel= input('请输入电话:')
Person(addname,relationshipList[addrelationship],addtel)
def Delperson():
name= input('请输入要删除的联系人姓名:')
del personDictionary[name]
def Search():
name= input('请输入要查找的联系人的姓名:')
if name in personDictionary:
print('姓名:%s,关系:%s,电话:%s' %(name,personDictionary[name]['relationship'],personDictionary[name]['tel']))
else:
print('联系人不存在。')
def Quit():
running= False
def SaveQuit():
f= open(addressbookFile,'wb')
p.dump(personDictionary,f)
f.close()
running= False
# 4.程序运行
running= True
# 5.判断通讯录文件是否存在
addressbookFile= 'addressbook.data'
# 6.如果存在,将文件读取到personDictionary字典中
if os.path.exists(addressbookFile):
f= open(addressbookFile,'rb')
personDictionary= p.load(f)
# 7.如果不存在,提示并创建
else:
jCommand= input('未找到通讯录文件,是否创建?yes/no ')
if jCommand== 'yes':
f= open(addressbookFile,'wb')
p.dump(personDictionary,f)
f.close()
elif jCommand== 'no':
running= False
# 8.while循环等待读取指令
while running:
command= input('请输入指令:')
# 9.如果指令为addperson,添加通讯录人员
if command== 'addperson':
Operation.Addperson()
continue
# 10.如果指令为delperson,删除通讯录人员
elif command== 'delperson':
Operation.Delperson()
continue
# 11.如果指令为search,查找通讯录人员
elif command== 'search':
Operation.Search()
continue
# 12.如果指令为quit,不保存退出程序
elif command== 'quit':
Operation.Quit()
break
# 13.如果指令为sq,保存更改并退出程序
elif command== 'sq':
Operation.SaveQuit()
break
else:
print('未找到指令!')
continue
6、演示
Python3 addressbook.py
请输入指令:search
请输入要查找的联系人的姓名:zhangsan
联系人不存在。
请输入指令:addperson
请输入姓名:zhangsan
请选择分组(0:家人,1:朋友,2:同事):1
请输入电话:1234567
请输入指令:search
请输入要查找的联系人的姓名:zhangsan
姓名:zhangsan,关系:朋友,电话:1234567
请输入指令:sq
$ Python3 addressbook.py
请输入指令:search
请输入要查找的联系人的姓名:zhangsan
姓名:zhangsan,关系:朋友,电话:1234567
请输入指令:addperson
请输入姓名:lisi
请选择分组(0:家人,1:朋友,2:同事):1
请输入电话:1234567
请输入指令:q
未找到指令!
请输入指令:quit
$ Python3 addressbook.py
请输入指令:search
请输入要查找的联系人的姓名:lisi
联系人不存在。
请输入指令:search
请输入要查找的联系人的姓名:zhangsan
姓名:zhangsan,关系:朋友,电话:1234567
请输入指令:quit
总结
0
投稿
猜你喜欢
- 哎,以前写博文的时候没注意,有些图片用QQ来截取,获得的图片文件名都是类似于QQ截图20120926174732-300×15.png的形式
- 分享人:轻侯设计师常有这样的疑惑:如何知道用户浏览网页的习惯?如何设计出符合用户使用习惯的网页?如何从搜索引擎带来更多的流量?眼动研究可以帮
- MaxDB是MySQL AB公司通过SAP认证的数据库。MaxDB数据库服务器补充了MySQL AB产品系列。某些MaxDB特性在MySQL
- SQL Server 2000 清理日志精品教程SQL Server 2000 数据库日志太大!如何清理SQL Server 2000的日志
- 什么是错误页面?是指链接指向的网页现在失效了,原因可能是用户输错了地址,也可能是网站结构调整,内容删除,或者地址变更都有可能出现这种情况。那
- 简介ORA-10458: standby database requires recoveryORA-01196: 文件 1 由于介质恢复会
- 一、Excel环境配置 服务器端的环境配置从参考资料上看,微软系列的配置应该都行,即:1.Win9x+PWS+Office2.Wi
- 用的昨天刚接触到的库,在windows下通过paramiko来登录linux系统并执行了几个命令,基本算是初试成功,后面会接着学习的。代码:
- 如果能,请问如何实现 谢谢set aa=server.cre
- 随着 CSS3 渐入人心,Web 字体逐渐成为话题,这种即将让未来的 Web 更加丰富多彩的技术(或者说标准)拥有多种可能,虽然 .webf
- 一、插入排序插入排序与我们平时打扑克牌非常相似,将新摸到的牌插入到已有的牌中合适的位置,而已有的牌往往是有序的。1.1 执行流程(1)在执行
- SQL Server数据库查询速度慢的原因有很多,常见的有以下几种:1、没有索引或者没有用到索引(这是查询慢最常见的问题,是程序设计的缺陷)
- <%dim conn ’定义一个连接变量 dim&nbs
- 本文实例讲述了JS实现淡入淡出图片效果的方法。分享给大家供大家参考,具体如下:效果:鼠标移入时,图片由半透明逐渐变成清晰,移出时,由清晰变为
- 准备篇1.配置防火墙,开启80端口、3306端口1 vim /etc/sysconfig/iptables2 -A INPUT -m sta
- 如下所示: out = subprocess.getstatusoutput('adb shell pm
- 本文实例讲述了wxPython主框架的简单用法,分享给大家供大家参考。具体如下:程序代码如下:import wx class MyApp(w
- 自己用python写了一个签到脚本,经过测试已经可以成功打卡,于是研究了一下windows定时运行程序1. 创建定时任务1.1 计划任务打开
- 以下代码已经在SQLServer2008上的示例数据库测试通过问题一:如何为数据进行加密与解密,避免使用者窃取机密数据? 对于一些敏感数据,
- 想查找mac下python的site-packages目录,如果用网上搜的安装目录之类的去找,进去每一层很多都是软链接形式存在,比较浪费时间