ThinkChat2.0新版上线,更智能更精彩,支持会话、画图、阅读、搜索等,送10W Token,即刻开启你的AI之旅 广告
[TOC] ## **综合应用 —— 名片管理系统** ## **系统需求** 1. 程序启动,显示名片管理系统欢迎界面,并显示功能菜单 ``` ************************************************** 欢迎使⽤【名⽚管理系统】V1.0 1. 新建名⽚ 2. 显⽰全部 3. 查询名⽚ 0. 退出系统 ************************************************** ``` * 用户用数字选择不同的功能 * 根据功能选择,执行不同的功能 * 用户名片需要记录用户的 姓名、电话、QQ、邮件 * 如果查询到指定的名片,用户可以选择 修改 或者 删除 名片 **步骤** 1. 框架搭建 2. 新增名片 3. 显示所有名片 4. 查询名片 5. 查询成功后修改、删除名片 6. 让 Python 程序能够直接运行 <br /> ### **01\. 框架搭建** 目标 * 搭建名片管理系统 框架结构 1. 准备文件,确定文件名,保证能够 在需要的位置 编写代码 2. 编写 主运行循环,实现基本的 用户输入和判断 **1.1 文件准备** 1.新建 cards\_main.py 保存 主程序功能代码 * 程序的入口 * 每一次启动名片管理系统都通过 main 这个文件启动 2.新建 cards\_tools.py 保存 所有名片功能函数 * 将对名片的 新增、查询、修改、删除 等功能封装在不同的函数中 **1.2 编写主运行循环** * 在 cards\_main 中添加一个 无限循环 ``` while True: # TODO(⼩明) 显⽰系统菜单 action = input("请选择操作功能:") print("您选择的操作是:%s" % action) # 根据⽤⼾输⼊决定后续的操作 if action in ["1", "2", "3"]: pass elif action == "0": print("欢迎再次使⽤【名⽚管理系统】") break else: print("输⼊错误,请重新输⼊") ``` **字符串判断** ``` if action in ["1", "2", "3"]: if action == "1" or action == "2" or action == "3": ``` 1. 使用 in 针对 列表 判断,避免使用 or 拼接复杂的逻辑条件 2. 没有使用 int 转换用户输入,可以避免 一旦用户输入的不是数字,导致程序运行出错 **pass** * pass 就是一个空语句,不做任何事情,一般用做占位语句 * 是为了保持程序结构的完整性 **无限循环** * 在开发软件时,如果 不希望程序执行后 立即退出 * 可以在程序中增加一个 无限循环 * 由用户来决定 退出程序的时机 **TODO 注释** * 在 `#` 后跟上 `TODO` ,用于标记需要去做的工作 ``` # TODO(作者/邮件) 显⽰系统菜单 ``` **1.3 在 cards\_tools 中增加四个新函数** ``` def show_menu(): '''显⽰菜单''' pass def new_card(): '''新建名⽚''' print("-" * 50) print("功能:新建名⽚") def show_all(): '''显⽰全部''' print("-" * 50) print("功能:显⽰全部") def search_card(): '''搜索名⽚''' print("-" * 50) print("功能:搜索名⽚") ``` **1.4 导入模块** * 在 cards\_main.py 中使用 import 导入 cards\_tools 模块 ``` import cards_tools ``` * 修改 while 循环的代码如下: ``` import cards_tools while True: cards_tools.show_menu() action = input("请选择操作功能:") print("您选择的操作是:%s" % action) # 根据⽤⼾输⼊决定后续的操作 if action in ["1", "2", "3"]: if action == "1": cards_tools.new_card() elif action == "2": cards_tools.show_all() elif action == "3": cards_tools.search_card() elif action == "0": print("欢迎再次使⽤【名⽚管理系统】") break else: print("输⼊错误,请重新输⼊:") ``` > 至此: cards_main 中的所有代码全部开发完毕! **1.5 完成 show_menu 函数** ``` def show_menu(): '''显⽰菜单''' print("*" * 50) print("欢迎使⽤【菜单管理系统】V1.0") print("") print("1. 新建名⽚") print("2. 显⽰全部") print("3. 查询名⽚") print("") print("0. 退出系统") print("*" * 50) ``` <br /> ### **02. 保存名片数据的结构** 程序就是用来处理数据的,而变量就是用来存储数据的 * 使用 字典 记录 每一张名片 的详细信息 * 使用 列表 统一记录所有的 名片字典 ![Snipaste_2020-08-27_11-10-43.png](http://i.loli.net/2020/08/27/n4xrE6LF3qOjfhv.png) <br /> **定义名片列表变量** 在`cards_tools`文件的顶部增加一个列表变量 ``` # 所有名⽚记录的列表 card_list = [] ``` **注意** 1. 所有名片相关操作,都需要使用这个列表,所以应该 定义在程序的顶部 2. 程序刚运行时,没有数据,所以是 空列表 <br /> ### **03. 新增名片** **3.1 功能分析** 1. 提示用户依次输入名片信息 2. 将名片信息保存到一个字典 3. 将字典添加到名片列表 4. 提示名片添加完成 **3.2 实现 new_card 方法** * 根据步骤实现代码 ``` def new_card(): '''新建名⽚''' print("-" * 50) print("功能:新建名⽚") # 1. 提⽰⽤⼾输⼊名⽚信息 name = input("请输⼊姓名:") phone = input("请输⼊电话:") qq = input("请输⼊ QQ 号码:") email = input("请输⼊邮箱:") # 2. 将⽤⼾信息保存到⼀个字典 card_dict = {"name": name, "phone": phone, "qq": qq, "email": email} # 3. 将⽤⼾字典添加到名⽚列表 card_list.append(card_dict) print(card_list) # 4. 提⽰添加成功信息 print("成功添加 %s 的名⽚" % card_dict["name"]) ``` > 技巧:在 PyCharm 中,可以使用 SHIFT + F6 统一修改变量名 <br /> ### **04. 显示所有名片** **4.1 功能分析** * 循环遍历名片列表,顺序显示每一个字典的信息 **4.2 基础代码实现** ``` def show_all(): '''显⽰全部''' print("-" * 50) print("功能:显⽰全部") for card_dict in card_list: print(card_dict) ``` * 显示效果不好! **4.3 增加标题和使用 \t 显示** ``` def show_all(): '''显⽰全部''' print("-" * 50) print("功能:显⽰全部") # 打印表头 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"])) ``` **4.4 增加没有名片记录判断** ``` def show_all(): '''显⽰全部''' print("-" * 50) print("功能:显⽰全部") # 1. 判断是否有名⽚记录 if len(card_list) == 0: print("提⽰:没有任何名⽚记录") return ``` **注意** * 在函数中使用 return 表示返回 * 如果在 return 后没有跟任何内容,只是表示该函数执行到此就不再执行后续的代码 <br /> ### **05. 查询名片** **5.1 功能分析** 1. 提示用户要搜索的姓名 2. 根据用户输入的姓名遍历列表 3. 搜索到指定的名片后,再执行后续的操作 **5.2 代码实现** * 查询功能实现 ``` def search_card(): '''搜索名⽚''' print("-" * 50) print("功能:搜索名⽚") # 1. 提⽰要搜索的姓名 find_name = input("请输⼊要搜索的姓名:") # 2. 遍历字典 for card_dict in card_list: if card_dict["name"] == find_name: print("姓名\t\t\t电话\t\t\tQQ\t\t\t邮箱") print("-" * 40) print("%s\t\t\t%s\t\t\t%s\t\t\t%s" % ( card_dict["name"], card_dict["phone"], card_dict["qq"], card_dict["email"])) print("-" * 40) # TODO(⼩明) 针对找到的字典进⾏后续操作:修改/删除 break else: print("没有找到 %s" % find_name) ``` * 增加名片操作函数:修改/删除/返回主菜单 ``` def deal_card(find_dict): """操作搜索到的名⽚字典 :param find_dict:找到的名⽚字典 """ print(find_dict) action_str = input("请选择要执⾏的操作 " "[1] 修改 [2] 删除 [0] 返回上级菜单") if action == "1": print("修改") elif action == "2": print("删除") ``` <br /> ### **06. 修改和删除** **6.1 查询成功后删除名片** * 由于找到的字典记录已经在列表中保存 * 要删除名片记录,只需要把列表中对应的字典删除即可 ``` elif action == "2": card_list.remove(find_dict) print("删除成功") ``` **6.2 修改名片** * 由于找到的字典记录已经在列表中保存 * 要修改名片记录,只需要把列表中对应的字典中每一个键值对的数据修改即可 ``` if action == "1": find_dict["name"] = input("请输⼊姓名:") find_dict["phone"] = input("请输⼊电话:") find_dict["qq"] = input("请输⼊QQ:") find_dict["email"] = input("请输⼊邮件:") print("%s 的名⽚修改成功" % find_dict["name"]) ``` **修改名片细化** * 如果用户在使用时,某些名片内容并不想修改,应该如何做呢?—— 既然系统提供的 input 函数不能满足需求,那么就新定义一个函数 input\_card\_info 对系统的 input 函数进行扩展 ``` def input_card_info(dict_value, tip_message): """输⼊名⽚信息 :param dict_value: 字典原有值 :param tip_message: 输⼊提⽰信息 :return: 如果输⼊,返回输⼊内容,否则返回字典原有值 """ # 1. 提⽰⽤⼾输⼊内容 result_str = input(tip_message) # 2. 针对⽤⼾的输⼊进⾏判断,如果⽤⼾输⼊了内容,直接返回结果 if len(result_str) > 0: return result_str # 3. 如果⽤⼾没有输⼊内容,返回 `字典中原有的值` else: return dict_value ``` <br /> ### **07. 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 ```