python初学者,用python实现基本的学生管理系统(python3)代码实例
作者:hsunnyc 发布时间:2023-07-01 11:40:01
标签:python,学生管理系统
这个是用python实现的基本的增删改查的学生管理系统吧,其中主要是对输入的数据进行合法性检测的问题,这次又对函数进行了练习!掌握函数更加熟练了!二话不说先贴代码,一切问题请看注释,都很详细,适合python3初学者!
"""
学生管理系统
主要特点:1.可以检测学号是否重复/有误(不为纯数字)
2.可以检测手机号是否合法(是否为纯数字)
3.可以检测性别是否为男或者女
4.能选择性修个学生的某个属性信息,比如只修改某个学生的手机号码
5.能够实现基本的增删改查
6.优化了代码
"""
name_list = [] # 存储学生信息字典,学生信息用字典存,再用列表存储字典
# 菜单
def display_menu():
print("-"*30)
print(" 学生管理系统 v8.8 ")
print("1.添加学生信息")
print("2.删除学生信息")
print("3.修改学生信息")
print("4.查询单个学生信息")
print("5.查询所有学生信息")
print("6.退出系统")
print("-"*30)
# 选择序号的获得
def get_choice():
selected_key = input("请输入选择的序号:")
return selected_key
# 检查性别是否合法
def check_sex(new_sex):
flag = True
while flag:
if new_sex == '男' or new_sex == '女':
flag = False
else:
new_sex = input("输入性别有误,请重新输入(男/女):")
return new_sex
# 检查电话号码是否合法
def check_phone(new_phone):
flag = True
while flag:
if new_phone.isdigit():
flag = False
else:
new_phone = input("您输入的电话号码有误,请重新输入:")
return new_phone
# 检查学号是否重复或者有误
def check_id(new_id):
flag = True
while flag:
# 先检查是不是纯数字再去考虑是否重复的事情,如果不是纯数字直接pass
if new_id.isdigit():
for i in range(len(name_list)):
if name_list[i]['id'] == new_id:
new_id = check_id(input("您输入的学号重复,请重新输入:"))
flag = False
else:
new_id = input("您输入的学号有误,请重新输入:")
return new_id
# 添加学生信息
def add_name():
new_info = {}
new_id = check_id(input("请输入学号:"))
new_info['id'] = new_id
new_name = input("请输入姓名:")
new_info['name'] = new_name
new_sex = check_sex(input("请输入性别(男/女):"))
new_info['sex'] = new_sex
new_phone = check_phone(input("请输入电话号码:"))
new_info['phone'] = new_phone
name_list.append(new_info)
print("添加成功!")
# 查询所有学生信息
def find_all():
print("="*30)
for name in name_list:
print(name['id'], name['name'], name['sex'], name['phone'])
print("=" * 30)
# 删除学生信息
def del_name():
del_id_is = input("请输入要删除的学生学号:")
flag = False
index = 0
for i in range(len(name_list)):
if name_list[i]['id'] == del_id_is:
flag = True
index = i
break
if flag:
name_list.pop(index)
print("删除成功!")
else:
print("学生未找到!请检查学号输入是否有误!")
# 名字修改细节函数
def choice_of_name(index):
while True:
choice = input("请输入要修改学生的(1.id 2.姓名 3.性别 4.电话号码,5.全部修改):")
if choice == '5':
new_id = input("请输入新的学号:")
name_list[index]['id'] = new_id
new_name = input("请输入新的姓名:")
name_list[index]['name'] = new_name
new_sex = check_sex(input("请输入性别(男/女):"))
name_list[index]['sex'] = new_sex
new_phone = check_phone(input("请输入电话号码:"))
name_list[index]['phone'] = new_phone
break
elif choice == '1':
new_id = input("请输入新的学号:")
name_list[index]['id'] = new_id
break
elif choice == '2':
new_name = input("请输入新的姓名:")
name_list[index]['name'] = new_name
break
elif choice == '3':
new_sex = check_sex(input("请输入性别(男/女):"))
name_list[index]['sex'] = new_sex
break
elif choice == '4':
new_phone = check_phone(input("请输入电话号码:"))
name_list[index]['phone'] = new_phone
break
else:
print("输入有误,请重新输入!")
# 修改学生信息
def re_name():
id_is = input("请输入要修改的学生学号:")
flag = False
index = 0
# 先找到要修改的学生的下标
for i in range(len(name_list)):
if name_list[i]['id'] == id_is:
flag = True
index = i
break
if flag:
choice_of_name(index)
print("修改成功!")
else:
print("修改失败,学生信息未找到!")
# 查询单个学生信息
def find_name():
find_id_is = input("请输入要查询的学生学号:")
flag = False
index = 0
for i in range(len(name_list)):
if name_list[i]['id'] == find_id_is:
flag = True
index = i
break
if flag:
print("学生查询到,学生信息为:")
print(name_list[index]['id'], name_list[index]['name'], name_list[index]['sex'], name_list[index]['phone'])
else:
print("学生未找到!")
def main():
exit_name = True
while exit_name:
display_menu()
key = get_choice()
if key == '1':
add_name()
elif key == '2':
del_name()
elif key == '3':
re_name()
elif key == '4':
find_name()
elif key == '5':
find_all()
elif key == '6':
exit_name = False
else:
print("请输入正确的数值!")
main()
以上所述是小编给大家介绍的用python实现学生管理系统详解整合网站的支持!
来源:https://blog.csdn.net/hsunnyc/article/details/89097679


猜你喜欢
- 本文代码将一些简单常用的SQL语句,拆分、封装成链式函数与终结函数,链式操作没有先后之分,实现傻瓜式mysql数据库操作。 同时学习下静态成
- 一、前言最近忙着在服务器上跑代码学习积累了一些经验技巧这里用来记录分享给大家二、创建虚拟环境用来跑代码下面我会以一个实例为模板,学习完之后,
- 本文实例讲述了Go语言写入字符串到文件的方法。分享给大家供大家参考。具体实现方法如下:package mainimport &q
- #!/usr/bin/perluse strict;use warnings;use re 'debug';sub test
- 如果电脑是第一次安装MySQL,一般不会出现这样的报错。如下图所示。starting the server失败,通常是因为上次安装的该软件未
- 写在前面如非特别说明,下文均基于Python3命名空间与作用于跟名字的绑定相关性很大,可以结合另一篇介绍Python名字、对象及其绑定的文章
- 支付宝支付正式环境:用营业执照,申请商户号,appid测试环境:沙箱环境:https://openhome.alipay.com/platf
- 在运营或者对各种 SDK 或者 API 进行调试的时候,邮件功能基本上都会被使用到。在测试的时候,可能很多人都会使用 SMTP 或者自己的邮
- 通过XSL转换XML文件 最近,我喜欢上了XML编程,但又苦于它的美观程度又不够,找了许多书才搞定。用XML好是蛮好,但它还是不太适合做显示
- 程序能实现什么a.完成gap值的自定义输入以及两条需比对序列的输入b.完成得分矩阵的计算及输出c.输出序列比对结果d.使用matplotli
- 一.使用库说明Golang中连接kafka可以使用第三方库:github.com/Shopify/sarama二.Kafka Produce
- mysql是我们项目中非常常用的数据型数据库。但是因为我们需要在数据库保存中文字符,所以经常遇到数据库乱码情况。下面就来介绍一下如何彻底解决
- 判断一个 list 是否为空传统的方式:if len(mylist): # Do something with my liste
- 导语九月初家里的熊孩子终于开始上学了!半个月过去了,小孩子每周都会带着一堆的数学作业回来,哈哈哈哈~真好,在家做作业就没时间打扰我写代码了。
- SQL执行步骤的具体分析先来看执行语句的顺序(8)select (9)distinct A (1)from Ta (3)join Tb (2
- 本文实例为大家分享了python实现自动抢火车票,供大家参考,具体内容如下splinter使用首先介绍一下splinter使用:plinte
- 题记:django如果要并和原有的数据库,那么就需要把现有数据库的表写入model.py中。一,在setting.py中配置好连接数据库的参
- 1.主要功能如下:1.classification分类2.Regression回归3.Clustering聚类4.Dimensionalit
- c shell perl php下的日期时间转换: 秒数与人类可读日期 scalar localtime 与 seconds since `
- 0x01 安装pyinotify>>> pip install pyinotify>>> import