老王讲IT:名片管理系统

news2024/10/5 11:02:04

综合应用 —— 名片管理系统

目标

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

  • 变量

  • 流程控制

  • 函数

  • 模块

开发 名片管理系统

系统需求

    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. 保存名片数据的结构

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

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

  • 使用 列表 统一记录所有的 名片字典

定义名片列表变量

  • 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
    1. 修改要运行的 主 python 文件,在第一行增加以下内容

#! /usr/bin/python3
    1. 修改 主 python 文件 的文件权限,增加执行权限

$ chmod +x cards_main.py
    1. 在需要时执行程序即可

./cards_main.py

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1601477.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

MySQL 基础使用

文章目录 一、Navicat 工具链接 Mysql二、数据库的使用1.常用数据类型2. 建表 create3. 删表 drop4. insert 插入数据5. select 查询数据6. update 修改数据7. delete 删除记录truncate table 删除数据 三、字段约束字段1. 主键 自增delete和truncate自增长字段的影响 2. 非空…

16 - Debian如何配置vsftpd(1)实现匿名上传下载

作者:网络傅老师 特别提示:未经作者允许,不得转载任何内容。违者必究! Debian如何配置vsftpd(1)实现匿名上传下载 《傅老师Debian小知识库系列之16》——原创 前言 傅老师Debian小知识库特点&#xff1a…

保护C#代码的艺术:深入浅出代码混淆技术

摘要 在C#开发中,代码的保护是一个不可忽视的问题。本文深入探讨了几种常用的C#代码混淆工具,帮助开发者理解如何有效地保护代码不被反编译。同时,本文也对混淆技术的优缺点进行了分析,并提供了一些实际使用的建议。 引言 C#是…

实战:通用二进制格式安装 MySQL(mysql-5.7.29)-2024.4.6(测试成功)

目录 文章目录 目录实验环境下载url安装相关包准备用户准备二进制程序准备环境变量准备配置文件生成数据库文件,并提取root密码准备服务脚本和启动修改口令测试登录安全初始化(可选)shell一键安装关于我最后 实验环境 mysql-5.7.29 centos7.6 1810软件位…

centos 更新系统时间

在CentOS中更新系统时间 1 检查当前时间: date 2 更新时间: 手动设置时间,但更常见的是通过网络同步时间。CentOS通常默认使用NTP(Network Time Protocol)来同步时间。 如果尚未安装NTP,请先安装它&#…

Servlet-Filter实现反爬虫

以前用DotNetCore实现过反爬虫功能。在tomcat里面可以利用Servlet的Filter类实现请求的控制来达到反爬虫功能,进而增强JRT的web安全。 实现黑名单过滤器,对在黑名单列表的IP的所有请求都跳转到警告页面,业务各种请求自行定义加入黑名单 /* …

leetcode:42.接雨水

单调栈解题思路: 需要知道当前遍历到的元素左边和右边第一个比该元素大的元素。 如果当前遍历到的元素大于栈顶元素,则该元素为栈顶元素右边第一个比它大的元素,此时,栈顶元素的栈内相邻元素是该元素左边第一个比它大的元素。【…

项目中,如何写 readme.md 文件 | 写项目总结

tips:注意写 1. readme文件:①项目文档(项目需求和设计文档、项目系统架构和技术文档、接口文档)、②项目结构、③启动项目。具体结构见下文。 2. 项目总结:技术栈、描述、主要工作!!需求及功…

Python SQL解析和转换库之sqlglot使用详解

概要 Python SQLGlot是一个基于Python的SQL解析和转换库,可以帮助开发者更加灵活地处理和操作SQL语句。本文将介绍SQLGlot库的安装、特性、基本功能、高级功能、实际应用场景等方面。 安装 安装SQLGlot库非常简单,可以使用pip命令进行安装: pip install sqlglot安装完成后…

MajorDoMo thumb.php 未授权RCE漏洞复现(CNVD-2024-02175)

0x01 产品简介 MajorDoMo是MajorDoMo社区的一个开源DIY智能家居自动化平台。 0x02 漏洞概述 MajorDoMo /modules/thumb/thumb.php接口处存在远程命令执行漏洞,未经身份验证的攻击者可利用此漏洞执行任意指令,获取服务器权限。 0x03 影响范围 MajorD…

十大排序——6.插入排序

这篇文章我们来介绍一下插入排序 目录 1.介绍 2.代码实现 3.总结与思考 1.介绍 插入排序的要点如下所示: 首先将数组分为两部分[ 0 ... low-1 ],[ low ... arr.length-1 ],然后,我们假设左边[ 0 ... low-1 ]是已排好序的部分…

MySQL 8 那些新来的参数,给那些快被淘汰的MYSQL DBA

开头还是介绍一下群,如果感兴趣PolarDB ,MongoDB ,MySQL ,PostgreSQL ,Redis, Oceanbase, Sql Server等有问题,有需求都可以加群群内有各大数据库行业大咖,CTO,可以解决你的问题。加群请联系 liuaustin3 ,(…

电视盒子哪个好?2024口碑网络电视盒子排行榜

多年来电视盒子始终占据重要地位,功能上并没有受到影响。在这么多品牌中哪些电视盒子的评价是最好的呢?小编根据各大电商平台的用户评价情况整理了口碑最好的网络电视盒子排行榜,跟着小编一起看看市面上的电视盒子哪个好吧。 TOP 1&#xff1…

ChatGPT在遥感领域中的应用

遥感技术主要通过卫星和飞机从远处观察和测量我们的环境,是理解和监测地球物理、化学和生物系统的基石。ChatGPT是由OpenAI开发的最先进的语言模型,在理解和生成人类语言方面表现出了非凡的能力。本课程重点介绍ChatGPT在遥感中的应用,人工智…

MATLAB 点到平面距离的简易计算 (61)

MATLAB 点到平面的垂直距离 (61) 一、算法介绍二、算法实现1.代码2.结果一、算法介绍 一行代码计算点到平面的距离,下面是MATLAB版本的实现方法, 使用一组自定义的点和平面验证,结果表明计算正确: 二、算法实现 1.代码 代码如下(示例): % 定义点的坐标 point = …

Leetcode. 12 整数转罗马数字

罗马数字包含以下七种字符: I, V, X, L,C,D 和 M。 字符 数值 I 1 V 5 X 10 L 50 C 100 D 500 M 1000 例…

OpenWrt 多拨负载均衡不起作用

检查 负载均衡->规则->Https->粘滞模式 是否启动,设置为 否 如果设置为是,那么根据官方描述: 来自相同源 IP 的流量,如果已经匹配过此规则并且在粘滞超时时间内,将会使用相同的 WAN 接口 意思就是如果你同一个…

pdf做批注编辑工具 最新pdf reader pro3.3.1.0激活版

PDF Reader Pro是一款功能强大的PDF阅读和编辑工具。它提供了多种工具和功能,帮助用户对PDF文档进行浏览、注释、编辑、转换和签名等操作。以下是PDF Reader Pro的一些主要特色: 最新pdf reader pro3.3.1.0激活版下载 多种查看模式:PDF Reade…

bufbomb level4 kaboom 64位思路

首先,开启地址随机化,观察buf的地址: 注意到bufn的差别巨大,也就是说滑动攻击(利用一堆空指令来增加命中率)的方法无效。那么只能另寻它路。 在getbufn的ret处打上断点,观察各寄存器的值&…

工业网络交换机的网络容错机制

在工业领域,网络的稳定性和可靠性至关重要。工业网络交换机作为工业网络的核心设备之一,其网络容错机制对于确保工业网络的稳定运行至关重要。本文将深入探讨工业网络交换机的网络容错机制,以及其在保障工业网络稳定性方面的重要作用。 1. 工…