Python综合应用名片管理系统案例详解


Posted in Python onJanuary 03, 2020

本文实例讲述了Python综合应用名片管理系统。分享给大家供大家参考,具体如下:

综合应用已经学习过的知识点:

  • 变量
  • 流程控制
  • 函数
  • 模块

开发 名片管理系统

系统需求

  1. 程序启动,显示名片管理系统欢迎界面,并显示功能菜单
**************************************************
欢迎使用【名片管理系统】V1.0

1. 新建名片
2. 显示全部
3. 查询名片

0. 退出系统
**************************************************
    1. 用户用数字选择不同的功能
    1. 根据功能选择,执行不同的功能
    1. 用户名片需要记录用户的 姓名、电话、QQ、邮件
    1. 如果查询到指定的名片,用户可以选择 修改 或者 删除 名片

步骤

  1. 框架搭建
  2. 新增名片
  3. 显示所有名片
  4. 查询名片
  5. 查询成功后修改、删除名片
  6. 让 Python 程序能够直接运行

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)

02. 保存名片数据的结构

程序就是用来处理数据的,而变量就是用来存储数据的

  • 使用 字典 记录 每一张名片 的详细信息

  • 使用 列表 统一记录所有的 名片字典
    Python综合应用名片管理系统案例详解
    定义名片列表变量

  • 在 cards_tools 文件的顶部增加一个 列表变量

# 所有名片记录的列表
card_list = []

注意

  1. 所有名片相关操作,都需要使用这个列表,所以应该 定义在程序的顶部
  2. 程序刚运行时,没有数据,所以是 空列表

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 统一修改变量名

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 后没有跟任何内容,只是表示该函数执行到此就不再执行后续的代码

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("删除")

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

07. LINUX 上的 Shebang 符号(#!)

  • #!这个符号叫做 Shebang 或者 Sha-bang
  • Shebang 通常在 Unix 系统脚本的中 第一行开头 使用
  • 指明 执行这个脚本文件 的 解释程序

使用 Shebang 的步骤

    1. 使用 which 查询 python3 解释器所在路径
$ which python3

修改要运行的 主 python 文件,在第一行增加以下内容

#! /usr/bin/python3

修改 主 python 文件 的文件权限,增加执行权限

$ chmod +x cards_main.py

在需要时执行程序即可

./cards_main.py

关于Python相关内容感兴趣的读者可查看本站专题:《Python函数使用技巧总结》、《Python面向对象程序设计入门与进阶教程》、《Python数据结构与算法教程》、《Python字符串操作技巧汇总》、《Python编码操作技巧总结》及《Python入门与进阶经典教程》

希望本文所述对大家Python程序设计有所帮助。

Python 相关文章推荐
Python调用C/C++动态链接库的方法详解
Jul 22 Python
Python运行报错UnicodeDecodeError的解决方法
Jun 07 Python
Flask实现跨域请求的处理方法
Sep 27 Python
python自动发送测试报告邮件功能的实现
Jan 22 Python
Python开启线程,在函数中开线程的实例
Feb 22 Python
解决Python3 控制台输出InsecureRequestWarning问题
Jul 15 Python
结合OpenCV与TensorFlow进行人脸识别的实现
Oct 10 Python
python 计算积分图和haar特征的实例代码
Nov 20 Python
keras中模型训练class_weight,sample_weight区别说明
May 23 Python
使用keras实现densenet和Xception的模型融合
May 23 Python
如何用python免费看美剧
Aug 11 Python
关于python爬虫应用urllib库作用分析
Sep 04 Python
Python tkinter常用操作代码实例
Jan 03 #Python
PyTorch中的padding(边缘填充)操作方式
Jan 03 #Python
nginx搭建基于python的web环境的实现步骤
Jan 03 #Python
Python如何使用字符打印照片
Jan 03 #Python
Pytorch.nn.conv2d 过程验证方式(单,多通道卷积过程)
Jan 03 #Python
如何基于python实现画不同品种的樱花树
Jan 03 #Python
Python基础之变量基本用法与进阶详解
Jan 03 #Python
You might like
PHP5 安装方法
2007/01/15 PHP
第七章 php自定义函数实现代码
2011/12/30 PHP
纯PHP生成的一个树叶图片画图例子
2014/04/16 PHP
php代码调试利器firephp安装与使用方法分析
2018/08/21 PHP
PHP校验15位和18位身份证号的类封装
2018/11/07 PHP
node.js中的fs.mkdirSync方法使用说明
2014/12/17 Javascript
jQuery平滑旋转幻灯片特效代码分享
2015/09/07 Javascript
精彩的Bootstrap案例分享 重点在注释!(选项卡、栅格布局)
2016/07/01 Javascript
Angular学习笔记之angular的$filter服务浅析
2016/11/12 Javascript
如何在Angular.JS中接收并下载PDF
2016/11/26 Javascript
快速掌握jquery分页插件jqPaginator的使用方法
2017/08/09 jQuery
JavaScript 点击触发复制功能实例详解
2018/11/02 Javascript
JavaScript中concat复制数组方法浅析
2019/01/20 Javascript
vue实现商品列表的添加删除实例讲解
2020/05/14 Javascript
详解Vite的新体验
2021/02/22 Javascript
[01:01:24]DOTA2上海特级锦标赛A组败者赛 EHOME VS CDEC第三局
2016/02/25 DOTA
[02:53]2018年度DOTA2最佳战队-完美盛典
2018/12/17 DOTA
Python的Socket编程过程中实现UDP端口复用的实例分享
2016/03/19 Python
详解python 拆包可迭代数据如tuple, list
2017/12/29 Python
对python的unittest架构公共参数token提取方法详解
2018/12/17 Python
使用opencv识别图像红色区域,并输出红色区域中心点坐标
2020/06/02 Python
CSS3中HSL和HSLA的简单使用示例
2015/07/14 HTML / CSS
HTML5 Canvas锯齿图代码实例
2014/04/10 HTML / CSS
澳洲Chemist Direct药房中文网:澳洲大型线上直邮药房
2019/11/04 全球购物
中间件分为哪几类
2016/09/18 面试题
计算机专业个人求职信范例
2013/09/23 职场文书
任命书模板
2014/06/04 职场文书
拓展训练激励口号
2014/06/17 职场文书
寻衅滋事罪辩护词
2015/05/21 职场文书
闪闪红星观后感
2015/06/08 职场文书
公司安全管理制度范本
2015/08/05 职场文书
爱护环境建议书
2015/09/14 职场文书
《跨越海峡的生命桥》教学反思
2016/02/18 职场文书
导游词之杭州西湖
2019/09/19 职场文书
2019年共青团工作条例最新版
2019/11/12 职场文书
TaiShan 200服务器安装Ubuntu 18.04的图文教程
2022/06/28 Servers