热门标签 | 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


推荐阅读
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • 技术分享:从动态网站提取站点密钥的解决方案
    本文探讨了如何从动态网站中提取站点密钥,特别是针对验证码(reCAPTCHA)的处理方法。通过结合Selenium和requests库,提供了详细的代码示例和优化建议。 ... [详细]
  • Python自动化处理:从Word文档提取内容并生成带水印的PDF
    本文介绍如何利用Python实现从特定网站下载Word文档,去除水印并添加自定义水印,最终将文档转换为PDF格式。该方法适用于批量处理和自动化需求。 ... [详细]
  • 本文详细解析了Python中的os和sys模块,介绍了它们的功能、常用方法及其在实际编程中的应用。 ... [详细]
  • 本文介绍了在Windows环境下使用pydoc工具的方法,并详细解释了如何通过命令行和浏览器查看Python内置函数的文档。此外,还提供了关于raw_input和open函数的具体用法和功能说明。 ... [详细]
  • 根据最新发布的《互联网人才趋势报告》,尽管大量IT从业者已转向Python开发,但随着人工智能和大数据领域的迅猛发展,仍存在巨大的人才缺口。本文将详细介绍如何使用Python编写一个简单的爬虫程序,并提供完整的代码示例。 ... [详细]
  • 前言--页数多了以后需要指定到某一页(只做了功能,样式没有细调)html ... [详细]
  • 本文深入探讨了 Java 中的 Serializable 接口,解释了其实现机制、用途及注意事项,帮助开发者更好地理解和使用序列化功能。 ... [详细]
  • XNA 3.0 游戏编程:从 XML 文件加载数据
    本文介绍如何在 XNA 3.0 游戏项目中从 XML 文件加载数据。我们将探讨如何将 XML 数据序列化为二进制文件,并通过内容管道加载到游戏中。此外,还会涉及自定义类型读取器和写入器的实现。 ... [详细]
  • 本章将深入探讨移动 UI 设计的核心原则,帮助开发者构建简洁、高效且用户友好的界面。通过学习设计规则和用户体验优化技巧,您将能够创建出既美观又实用的移动应用。 ... [详细]
  • 扫描线三巨头 hdu1928hdu 1255  hdu 1542 [POJ 1151]
    学习链接:http:blog.csdn.netlwt36articledetails48908031学习扫描线主要学习的是一种扫描的思想,后期可以求解很 ... [详细]
  • 本文详细介绍了C语言中链表的两种动态创建方法——头插法和尾插法,包括具体的实现代码和运行示例。通过这些内容,读者可以更好地理解和掌握链表的基本操作。 ... [详细]
  • 在维护公司项目时,发现按下手机的某个物理按键后会激活相应的服务,并在屏幕上模拟点击特定坐标点。本文详细介绍了如何使用ADB Shell Input命令来模拟各种输入事件,包括滑动、按键和点击等。 ... [详细]
  • 尽管使用TensorFlow和PyTorch等成熟框架可以显著降低实现递归神经网络(RNN)的门槛,但对于初学者来说,理解其底层原理至关重要。本文将引导您使用NumPy从头构建一个用于自然语言处理(NLP)的RNN模型。 ... [详细]
  • 本题探讨如何通过最大流算法解决农场排水系统的设计问题。题目要求计算从水源点到汇合点的最大水流速率,使用经典的EK(Edmonds-Karp)和Dinic算法进行求解。 ... [详细]
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社区 版权所有