热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

python实现学员管理系统(增删改查)

1.1系统简介需求:进⼊系统显示系统功能界⾯,功能如下:1、添加学员2、删除学员3、修改学员信息4、查询学员信息5、显示所有学员信息6、退

1.1 系统简介


需求:进⼊系统显示系统功能界⾯,功能如下:

        1、添加学员

        2、删除学员

        3、修改学员信息

        4、查询学员信息

        5、显示所有学员信息

        6、退出系统

系统共6个功能,⽤户根据⾃⼰需求选取。

1.2 步骤分析

1. 显示功能界⾯
2. ⽤户输⼊功能序号
3. 根据⽤户输⼊的功能序号,执⾏不同的功能(函数)

        3.1 定义函数

        3.2 调⽤函数

1.3 需求实现

1.3.1 显示功能界⾯

定义函数 print_info ,负责显示系统功能。



def print_info():print('-' * 20)print('欢迎登录学员管理系统')print('1: 添加学员')print('2: 删除学员')print('3: 修改学员信息')print('4: 查询学员信息')print('5: 显示所有学员信息')print('6: 退出系统')print('-' * 20)print_info()

1.3.2 ⽤户输⼊序号,选择功能



user_num = input('请选择您需要的功能序号:')

1.3.3 根据⽤户选择,执⾏不同的功能



if user_num == '1':print('添加学员')
elif user_num == '2':print('删除学员')
elif user_num == '3':print('修改学员信息')
elif user_num == '4':print('查询学员信息')
elif user_num == '5':print('显示所有学员信息')
elif user_num == '6':print('退出系统')

⼯作中,需要根据实际需求调优代码。

        1. ⽤户选择系统功能的代码需要循环使⽤,直到⽤户主动退出系统。

        2. 如果⽤户输⼊1-6以外的数字,需要提示⽤户。



while True:# 1. 显示功能界⾯print_info()# 2. ⽤户选择功能user_num = input('请选择您需要的功能序号:')# 3. 根据⽤户选择,执⾏不同的功能if user_num == '1':print('添加学员')elif user_num == '2':print('删除学员')elif user_num == '3':print('修改学员信息')elif user_num == '4':print('查询学员信息')elif user_num == '5':print('显示所有学员信息')elif user_num == '6':print('退出系统')else:print('输⼊错误,请重新输⼊!!!')

1.3.4 定义不同功能的函数

        所有功能函数都是操作学员信息,所有存储所有学员信息应该是⼀个全局变量,数据类型为列表


info = []

1.3.4.1 添加学员

需求分析
1. 接收⽤户输⼊学员信息,并保存
2. 判断是否添加学员信息

        2.1 如果学员姓名已经存在,则报错提示

        2.2 如果学员姓名不存在,则准备空字典,将⽤户输⼊的数据追加到字典,再列表追加字典数据

3. 对应的if条件成⽴的位置调⽤该函数
代码实现:


def add_info():""" 添加学员 """# 接收⽤户输⼊学员信息new_id = input('请输⼊学号:')new_name = input('请输⼊姓名:')new_tel = input('请输⼊⼿机号:')# 声明info是全局变量global info# 检测⽤户输⼊的姓名是否存在,存在则报错提示for i in info:if new_name == i['name']:print('该⽤户已经存在!')return# 如果⽤户输⼊的姓名不存在,则添加该学员信息info_dict = {}# 将⽤户输⼊的数据追加到字典info_dict['id'] = new_idinfo_dict['name'] = new_nameinfo_dict['tel'] = new_tel# 将这个学员的字典数据追加到列表info.append(info_dict)print(info)

1.3.4.2 删除学员

需求分析
按⽤户输⼊的学员姓名进⾏删除
1. ⽤户输⼊⽬标学员姓名
2. 检查这个学员是否存在

        2.1 如果存在,则列表删除这个数据

        2.2 如果不存在,则提示该⽤户不存在

3. 对应的if条件成⽴的位置调⽤该函数
代码实现:


# 删除学员
def del_info():"""删除学员"""# 1. ⽤户输⼊要删除的学员的姓名del_name = input('请输⼊要删除的学员的姓名:')global info# 2. 判断学员是否存在:如果输⼊的姓名存在则删除,否则报错提示for i in info:if del_name == i['name']:info.remove(i)breakelse:print('该学员不存在')print(info)

1.3.4.3 修改学员信息



需求分析
1. ⽤户输⼊⽬标学员姓名
2. 检查这个学员是否存在

        2.1 如果存在,则修改这位学员的信息,例如⼿机号

        2.2 如果不存在,则报错

3. 对应的if条件成⽴的位置调⽤该函数
代码实现:



# 修改函数
def modify_info():"""修改函数"""# 1. ⽤户输⼊要修改的学员的姓名modify_name = input('请输⼊要修改的学员的姓名:')global info# 2. 判断学员是否存在:如果输⼊的姓名存在则修改⼿机号,否则报错提示for i in info:if modify_name == i ['name']:i['tel'] = input('请输⼊新的⼿机号:')breakelse:print('该学员不存在')print(info)

1.3.4.4 查询学员信息

需求分析
1. ⽤户输⼊⽬标学员姓名
2. 检查学员是否存在

        2.1 如果存在,则显示这个学员的信息

        2.2 如果不存在,则报错提示

3. 对应的if条件成⽴的位置调⽤该函数
代码实现:



# 查询学员
def search_info():"""查询学员"""# 1. 输⼊要查找的学员姓名:search_name = input('请输⼊要查找的学员姓名:')global info# 2. 判断学员是否存在:如果输⼊的姓名存在则显示这位学员信息,否则报错提示for i in info:if search_name == i['name']:print('查找到的学员信息如下:----------')print(f"该学员的学号是{i['id']}, 姓名是{i['name']}, ⼿机号是{i['tel']}")breakelse:print('该学员不存在')

1.3.4.5 显示所有学员信息

需求分析
        打印所有学员信息
代码实现:


# 显示所有学员信息
def print_all():""" 显示所有学员信息 """print('学号\t姓名\t⼿机号')for i in info:print(f'{i["id"]}\t{i["name"]}\t{i["tel"]}')

1.3.4.6 退出系统

        在⽤户输⼊功能序号 6 的时候要退出系统,代码如下:


......elif user_num == '6':exit_flag = input('确定要退出吗?yes or no')if exit_flag == 'yes':break


推荐阅读
  • #点球小游戏fromrandomimportchoiceimporttimescore[0,0]direction[left,center,right]defkick() ... [详细]
  • 反向投影技术主要用于在大型输入图像中定位特定的小型模板图像。通过直方图对比,它能够识别出最匹配的区域或点,从而确定模板图像在输入图像中的位置。 ... [详细]
  • Python处理Word文档的高效技巧
    本文详细介绍了如何使用Python处理Word文档,涵盖从基础操作到高级功能的各种技巧。我们将探讨如何生成文档、定义样式、提取表格数据以及处理超链接和图片等内容。 ... [详细]
  • 本文详细探讨了HTML表单中GET和POST请求的区别,包括它们的工作原理、数据传输方式、安全性及适用场景。同时,通过实例展示了如何在Servlet中处理这两种请求。 ... [详细]
  • 如何使用PyCharm及常用配置详解
    对于一枚pycharm工具的使用新手,正确了解这门工具的配置及其使用,在使用过程中遇到的很多问题也可以迎刃而解,文中有非常详细的介绍, ... [详细]
  • 本文详细介绍了Python中函数的基本概念,包括函数的定义与调用、文档注释、参数传递(形参与实参)、返回值以及函数嵌套。通过具体示例和解释,帮助读者掌握函数在编程中的应用。 ... [详细]
  • 在现代Web应用中,当用户滚动到页面底部时,自动加载更多内容的功能变得越来越普遍。这种无刷新加载技术不仅提升了用户体验,还优化了页面性能。本文将探讨如何实现这一功能,并介绍一些实际应用案例。 ... [详细]
  • Ihaveastringwithquotesaroundthepathasfollows:我在路径周围有一个带引号的字符串,如下所示:C:\ProgramFiles(x ... [详细]
  • 在软件开发过程中,MD5加密是一种常见的数据保护手段。本文将详细介绍如何在C#中使用两种不同的方式来实现MD5加密:字符串加密和流加密。 ... [详细]
  • 本文探讨了在C++中如何有效地清空输入缓冲区,确保程序只处理最近的输入并丢弃多余的输入。我们将介绍一种不阻塞的方法,并提供一个具体的实现方案。 ... [详细]
  • 在Oracle数据库中,使用Dbms_Output.Put_Line进行输出调试时,若单行字符超过255个,则会遇到ORA-20000错误。本文介绍了一种有效的方法来处理这种情况,通过创建自定义包和视图,实现对长字符串的分割和正确输出。 ... [详细]
  • 配置多VLAN环境下的透明SQUID代理
    本文介绍如何在包含多个VLAN的网络环境中配置SQUID作为透明网关。网络拓扑包括Cisco 3750交换机、PANABIT防火墙和SQUID服务器,所有设备均部署在ESXi虚拟化平台上。 ... [详细]
  • 对象自省自省在计算机编程领域里,是指在运行时判断一个对象的类型和能力。dir能够返回一个列表,列举了一个对象所拥有的属性和方法。my_list[ ... [详细]
  • 本文由杨勇和思远于2012年12月27日撰写,主要探讨了如何使用PHP进行网页内容抓取,特别是针对字符较多的网站。文章详细介绍了正则表达式失效的原因,并提供了优化方法,同时展示了如何抓取淘宝服饰栏、天气信息以及IP地址对应的地理位置。 ... [详细]
  • 深入理解Lucene搜索机制
    本文旨在帮助读者全面掌握Lucene搜索的编写步骤、核心API及其应用。通过详细解析Lucene的基本查询和查询解析器的使用方法,结合架构图和代码示例,带领读者深入了解Lucene搜索的工作流程。 ... [详细]
author-avatar
白云朵朵12
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有