Python题目:学生信息管理系统
选用list、tuple、dictionary或map等数据结构,存储X个学生的三门课的成绩(机器学习、Python程序设计、研究生英语),并实现以下功能:
- 1.添加学生信息
- 2.修改学生信息
- 3.删除学生
- 4.添加学生的成绩
- 5.修改学生成绩
- 6.按姓名或者学号查找学生,显示学生信息及三门课的成绩,以及排名
- 7.学生成绩统计(每门课的平均分、最高分、最低分)
现在把另一个高级版也放出来了,拥有图像界面显示,MySQL数据库操作: -2019/11/20
stu_number = {
"182085211002":"张三",
"182085211003":"a",
"182085211004":"b",
"182085211005":"a",
"182085211006":"d",
"182085211007":"张三",
"182085211008":"f",
}
stu_info = [
["182085211002","张三","男","汉族","100","99","98"],
["182085211003","a","男","汉族","60","99","98"],
["182085211004","b","男","汉族","100","88","98"],
["182085211005","a","男","汉族","100","99","45"],
["182085211006","d","男","汉族","100","75","98"],
["182085211007","张三","男","汉族","100","75","98"],
["182085211008","f","男","汉族","50","60","60"],
]
rank = {}
# 添加学生信息
def add_stu(stu_id):
stu = []
if stu_id in stu_number.keys(): # 判断'stu_num'是否存在于stu_number的键中
print('该学生已存在,请勿重复添加!')
else:
stu_name = input("请输入学生姓名:")
stu_number[stu_id] = stu_name
stu.append(stu_id)
stu.append(stu_name)
stu.append(input("请输入学生性别:"))
stu.append(input("请输入学生民族:"))
stu.append("无")
stu.append("无")
stu.append("无")
stu_info.append(stu)
print_stu(stu_id)
# 修改学生信息
def modif_stu(stu):
if stu in stu_number.keys(): # 判断'stu_num'是否存在于stu_number的键中
print_stu(stu)
print("该学生信息如上,请输入要修改的项目:")
while True:
cmd = input("1、姓名 2、性别 3、民族 (输入q返回上级菜单):")
if cmd == 'q':
break
elif cmd == '1':
index = find_stu(stu)
for i in index:
stu_info[i][1] = input("请输入修改后的姓名:")
elif cmd == '2':
index = find_stu(stu)
for i in index:
stu_info[i][2] = input("请输入修改后的性别:")
elif cmd == '3':
index = find_stu(stu)
for i in index:
stu_info[i][3] = input("请输入修改后的民族:")
print("修改后的信息如下:")
print_stu(stu)
else:
print('该学生不存在,请添加或重新输入!')
# 删除学生
def delete_stu(stu):
if stu in stu_number.keys(): # 判断'stu_num'是否存在于stu_number的键中
print_stu(stu)
cmd = input("该学生信息如上,确定是否删除?(Y/N):")
if cmd == 'Y':
index = find_stu(stu)
for i in index:
del stu_info[i]
print("该学生已删除!")
else:
print('该学生不存在,请添加或重新输入!')
# 添加学生成绩
def add_stu_val(stu_id):
if stu_id in stu_number.keys(): # 判断'stu_num'是否存在于stu_number的键中
print_stu(stu_id)
print("该学生信息如上")
index = find_stu(stu_id)
for i in index:
stu_info[i][4] = input("请输入机器学习成绩:")
stu_info[i][5] = input("请输入Python程序设计成绩:")
stu_info[i][6] = input("请输入研究生英语:")
print("添加成绩结果如下:")
print_stu(stu)
else:
print('该学生不存在,请添加或重新输入!')
# 修改学生成绩
def modif_stu_val(stu):
if stu in stu_number.keys(): # 判断'stu_num'是否存在于stu_number的键中
print_stu(stu)
print("该学生信息如上,请输入要修改的课程:")
while True:
cmd = input("1、机器学习 2、Python程序设计 3、研究生英语 (输入q返回上级菜单):")
if cmd == 'q':
break
elif cmd == '1':
index = find_stu(stu)
for i in index:
stu_info[i][4] = input("请输入修改后的成绩:")
elif cmd == '2':
index = find_stu(stu)
for i in index:
stu_info[i][5] = input("请输入修改后的成绩:")
elif cmd == '3':
index = find_stu(stu)
for i in index:
stu_info[i][6] = input("请输入修改后的成绩:")
print("修改后的信息如下:")
print_stu(stu)
else:
print('该学生不存在,请添加或重新输入!')
# 排名
def ranking():
to_rank = {}
for stu in stu_info:
if stu[4]=='无' or stu[5]=='无' or stu[6]=='无':
to_rank[stu[0]] = 0
rank[stu[0]] = '无'
else:
to_rank[stu[0]] = (int(stu[4])+int(stu[5])+int(stu[6]))/3
ranked = sorted(to_rank.items(),key = lambda x:x[1],reverse = True)
num = 1
re_num = 0 #分一样
for i in range(len(ranked)):
if i!=0:
if ranked[i][1]==ranked[i-1][1]: #考虑分数一样的情况 排名相同
re_num+=1
rank[ranked[i][0]] = num
else:
num = num + 1 + re_num #分数不一样 排名加一 如果有重复排名则加上
rank[ranked[i][0]] = (num + re_num)
re_num = 0
else: #存第一名
rank[ranked[i][0]] = num
# 按姓名或者学号查找学生,返回值为列表 列表里的值为该学生数据位置
# 如果有重名学生,则返回在列表返回多个学生
def find_stu(stu):
stu_index = []
for i in stu_info:
try:
if i.index(stu) != None: #如果能查找到
stu_index.append(stu_info.index(i))
except:pass
return stu_index
# 根据姓名或者学号显示学生信息及三门课的成绩、排名
def print_stu(stu):
ranking() # 排名
stu_index = find_stu(stu)
if len(stu_index) == 0:
print("无此学生,请核对后重新输入!")
for i in stu_index:
the_stu = stu_info[i]
print("\t姓名:",the_stu[1])
print("\t学号:", the_stu[0])
print("\t性别:", the_stu[2])
print("\t民族:", the_stu[3])
print("\t机器学习成绩:", the_stu[4])
print("\tPython程序设计成绩:", the_stu[5])
print("\t研究生英语成绩::", the_stu[6])
print("\t排名::", rank[the_stu[0]])
print("--------------------------")
def statistics():
machine_learning_max = 0
python_max = 0
english_max = 0
machine_learning_min = 100
python_min = 100
english_min = 100
machine_learning = 0
python = 0
english = 0
num = 0
for stu in stu_info:
if stu[4]!='无' and stu[5]!='无' and stu[6]!='无':
num += 1
machine_learning += float(stu[4])
python += float(stu[5])
english += float(stu[6])
if float(stu[4]) > machine_learning_max: machine_learning_max = float(stu[4])
if float(stu[4]) < machine_learning_min: machine_learning_min = float(stu[4])
if float(stu[5]) > python_max: python_max = float(stu[5])
if float(stu[5]) < python_min: python_min = float(stu[5])
if float(stu[6]) > english_max: english_max = float(stu[6])
if float(stu[6]) < english_min: english_min = float(stu[6])
machine_learning = machine_learning/num
python = python/num
english = english/num
print("学生成绩统计如下:")
print("机器学习:")
print("\t平均分:%.2f,最高分:%.2f,最低分:%.2f" % (machine_learning,machine_learning_max,machine_learning_min))
print("Python程序设计:")
print("\t平均分:%.2f,最高分:%.2f,最低分:%.2f" % (python, python_max, python_min))
print("研究生英语:")
print("\t平均分:%.2f,最高分:%.2f,最低分:%.2f" % (english, english_max, english_min))
while True:
print("--------------------------")
print("请输入以下命令进行操作:")
print("\t1 添加学生信息")
print("\t2 修改学生信息")
print("\t3 删除学生")
print("\t4 添加学生的成绩")
print("\t5 修改学生成绩")
print("\t6 按姓名或者学号查找学生,显示学生信息及三门课的成绩,以及排名")
print("\t7 学生成绩统计")
print("\texit 退出系统!")
cmd = input("请输入命令:")
if cmd == 'exit': # 退出系统!
break
elif cmd == '1': # 添加学生信息
print("--------------------------")
while True:
stu_id = input("请输入要添加学号(输入q返回上级菜单):")
if stu_id == 'q':
break
add_stu(stu_id)
elif cmd == '2': # 修改学生信息
print("--------------------------")
while True:
stu = input("请输入要修改的学生学号(输入q返回上级菜单):")
if stu == 'q':
break
modif_stu(stu)
elif cmd == '3': # 删除学生
print("--------------------------")
while True:
stu = input("请输入要删除的学生学号(输入q返回上级菜单):")
if stu == 'q':
break
delete_stu(stu)
elif cmd == '4': # 添加学生的成绩
print("--------------------------")
while True:
stu = input("请输入要添加成绩的学号(输入q返回上级菜单):")
if stu == 'q':
break
add_stu_val(stu)
elif cmd == '5': # 修改学生成绩
print("--------------------------")
while True:
stu = input("请输入要修改成绩的学号(输入q返回上级菜单):")
if stu == 'q':
break
modif_stu_val(stu)
elif cmd == '6': # 按姓名或者学号查找学生,显示学生信息及三门课的成绩,以及排名
ranking() # 排名
print("--------------------------")
while True:
stu = input("请输入要查询的学生姓名或学号(输入q返回上级菜单):")
if stu == 'q':
break
print_stu(stu)
elif cmd == '7': # 学生成绩统计
print("--------------------------")
statistics()