名片管理系统
目标
综合已经学习过的知识点
- 变量
- 流程控制
- 函数
- 模块
开发 名片管理系统
框架搭建
程序框架就是能简单运行的程序,但是这个程序还很不完善,有了基本的雏形
- 搭建名片管理系统框架结构
- 准备文件,确定文件名,保证能够在需要的位置编写代码
编写主运行循环,实现基本的用户输入和判断
文件准备
- 新建
cards_main.py
保存主程序功能代码- 程序的入口
- 每一次启动名片管理系统都通过
main
这个文件启动
- 新建
cards_tools.py
保存所有名片功能函数- 将对名片的新增,查询,修改,删除等功能封装在不同的函数中
编写主运行循环
- 在
cards_main
中添加一个无限循环
while True: # TODO(Rowry)显示功能菜单 action_str = input("请选择希望执行的操作: ").strip() print("您选择的操作是 [%s]" % action_str) # 1,2,3 针对名片进行操作 if action_str in ["1", "2", "3"]: # 新增名片 if action_str == "1": pass # 显示全部 elif action_str == "2": pass # 查询名片 else: pass # 在开发程序时,如果不希望立刻编写 => pass关键字 # pass # 0 退出系统 elif action_str == "0": print("欢迎再次使用 <名片管理系统>") break # 其他内容输入错误,需要提示用户 else: print("您输入的不正确,请重新选择")
cards_main知识点小结
字符串判断
if action in ["1","2","3"]:
if action =="1" or action == "2" or action =="3":
- 使用
in
针对列表判断,避免使用or
拼接复杂的逻辑条件 - 没有使用
int
转换用户的输入,可以避免一旦用户输入的不是数字,导致程序运行出错 => 一般都是输入的str,然后再进行转换的
pass
pass
就是一个空语句,不做任何事情,一般用作占位语句- 是为了保持程序结构的完整性 => 写程序整体框架的时候就可以使用pass
无限循环
- 在开发软件时,如果不希望程序执行后立即退出,可以在程序中增加一个无限循环,由用户来决定退出程序的时机
TODO注释
- 在
#
后跟上TODO
,用于标记需要去做的工作
# TODO(作者/邮件) 显示系统菜单
在cards_tools
中增加四个新函数
def show_menu(): """显示菜单 """ pass def new_card(): """新建名片 """ print("-" * 50) print("功能:新建名片") def show_all(): """显示全部 """ print("-" * 50) print("功能:显示全部") def search_card(): """搜索名片 """ print("-" * 50) print("功能:搜索名片")
导入模块
- 在
cards_main.py
中使用import
导入cards_tools
模块 - 修改后的代码如下
import cards_tools while True: # 显示功能菜单 cards_tools.show_menu() action_str = input("请选择希望执行的操作: ").strip() print("您选择的操作是 [%s]" % action_str) # 1,2,3 针对名片进行操作 if action_str in ["1", "2", "3"]: # 新增名片 if action_str == "1": cards_tools.new_card() # 显示全部 elif action_str == "2": cards_tools.show_all() # 查询名片 else: cards_tools.search_card() # 在开发程序时,如果不希望立刻编写 => pass关键字 # pass # 0 退出系统 elif action_str == "0": print("欢迎再次使用 <名片管理系统>") break # 其他内容输入错误,需要提示用户 else: print("您输入的不正确,请重新选择")
至此:cards_main
中的所有代码全部开发完毕!
完成show_menu
函数
def show_menu(): """显示菜单 """ print("*" * 50) print("欢迎使用【菜单管理系统】V1.0") print("") print("1. 新建名片") print("2. 显示全部") print("3. 查询名片") print("") print("0. 退出系统") print("*" * 50)
保存名片的数据结构
程序就是用来处理数据的,而变量就是用来存储数据的
- 使用字典记录每一张名片的详细信息
- 使用列表统一记录所有的名片字典
定义名片列表变量
- 在
cards_tools
文件的顶部增加以恶个列表变量
# 所有名片记录的列表 card_list = []
注意:
- 所有名片相关操作,都需要使用这个列表,所以应该定义在程序的顶部
- 程序刚运行时,没有数据,所以时空列表
新增名片
功能分析
- 提示用户依次输入名片信息
- 将名片信息保存到一个字典
- 将字典添加到名片列表
- 提示名片添加完成
实现new_card()
def new_card(): """ 新增名片 :return: """ # 1. 提示用户依次输入名片信息 name_str = input("请输入姓名: ").strip() phone_str = input("请输入电话: ").strip() qq_str = input("请输入QQ: ").strip() email_str = input("请输入邮箱: ").strip() # 2. 将名片信息保存到一个字典 card_dict = {"name":name_str, "phone":phone_str, "qq":qq_str, "email":email_str} # 3. 将字典添加到名片列表 card_list.append(card_dict) print(card_list) # 4. 提示名片添加完成 print("添加 %s 的名片成功! "% name_str)
技巧: 在IDE中 Refactor => Rename => 可以快速的统一修改变量的名字
显示所有名片
功能分析
- 循环遍历名片列表,顺序显示每一个字典的信息
def show_all(): """ 显示所有名片 :return: """ print("-" * 50) print("功能: 显示所有名片") # 判断是否存在名片记录,如果没有,提示用户并返回 if len(card_list) == 0: print("当前没有任何名片记录,请使用新增功能添加卡片!") # => 也是使用return提前结束 return # 打印表头 for name in ["姓名", "电话", "QQ", "邮箱"]: print(name, end="\t\t") print() # 打印分割线 print("=" * 50) # 遍历名片列表依次输出字典信息 for card_dict in card_list: print( "%s\t\t %s \t\t %s \t\t %s" % (card_dict["name"], card_dict["phone"], card_dict["qq"], card_dict["email"]))
注意:
- 在函数中
return
表示返回 - 如果
return
后米有跟任何内容,只是表示该函数执行到此就不再执行后续的代码,返回调用函数处
查询名片
功能分析
- 提示用户要搜索的姓名
- 根据用户输入的姓名遍历列表
- 搜索到指定的名片后,再执行后续的操作
- 查询功能实现
def search_card(): """ 搜索名片 :return: """ print("-" * 50) print("功能: 搜索名片") # 1. 提示用户输入要搜索的姓名 find_name = input("请输入要搜索的姓名: ") # 2. 遍历名片列表,查询要搜索的姓名 # 这里利用了 for-else 的语法 for card_dict in card_list: if card_dict["name"] == find_name: print("姓名\t\t电话\t\tQQ\t\t邮箱") print("=" * 50) print( "%s\t\t %s \t\t %s \t\t %s" % ( card_dict["name"], card_dict["phone"], card_dict["qq"], card_dict["email"])) deal_card(card_dict) break else: print("抱歉,没有找到 %s 的相关信息" % find_name)
- 增加名片操作函数: 修改/删除/返回主菜单
def deal_card(find_card): """ 处理查找到的名片 :param find_card: 查找到的名片 :return: """ action_str = input("请选择要执行的操作" " [1] 修改 [2] 删除 [0] 返回上级菜单").strip() if action_str == "1": # 这里的函数值传递 => 对象引用 find_card["name"]=input_card_info(find_card["name"],"修改姓名为[回车不修改]: ") find_card["phone"]=input_card_info(find_card["phone"],"修改电话为[回车不修改]: ") find_card["qq"]=input_card_info(find_card["qq"],"修改QQ为[回车不修改]: ") find_card["email"]=input_card_info(find_card["email"],"修改邮箱为[回车不修改]: ") print("修改名片成功!") elif action_str == "2": # 直接这样就可以删除列表中的字典 card_list.remove(find_card) print("已经成功删除 %s 的信息!" % find_card["name"])
- 修改名片细化
- 如果用户在使用时,某些名片内容并不想修改 => 系统提供的
input()
不能满足需求,那么就新定义一个函数input_card_info()
对系统的input()
进行扩展
def input_card_info(dict_value,tip_message): """ 系统的input()不满足需求,针对该名片管理系统设计的输入函数 :param dict_value: 字典中原有的值 :param tip_message: 输入的提示文字 :return: 如果用户输入了内容,就返回内容,否则返回字典中原有的值 """ # 1. 提示用户输入内容 result_str = input(tip_message).strip() # 2. 针对用户的输入进行判断,如果用户输入了内容,直接返回结果 if len(result_str) > 0: return result_str # 3. 如果用户没有输入内容,返回字典中原有的值 else: return dict_value
- 如果用户在使用时,某些名片内容并不想修改 => 系统提供的
Linux上的Shebang
符号(#!
)
#!
这个符号叫做Shebang
或者Sha-bang
Shebang
通常在unix
系统脚本中第一行开头使用- 作用: 指明执行这个脚本文件的解释程序
使用Shebang的步骤
- 使用
which
查询python3
解释器所在的路径
$ which python3
- 修改要运行的主python文件,在一第行增加以下内容
#! /usr/bin/python3
- 修改主python文件的文件权限,增加执行权限
$ chmod +x cards_main.py
- 在需要时执行程序即可
./cards_main.py