赞
踩
随着高校的扩招,需要处理的学生信息日趋加大,不仅花费大量的教师资源,处理的
效率还十分低下。为提高学生管理的管理水平,优化资源,尽可能降低管理成本成为学生
管理的新课题,学生管理系统是从学生管理现状出发,根据学生管理的新要求进行开发设
计的,它解决了学生管理数据信息量大,修改不方便,对一系列数据进行分析时花费时间
长等问题,帮助学生管理人员有效管理学生信息,成为管理高校中必不可少的管理工具。
学生管理系统具备的功能:
1. 添加学生及成绩信息
2.将学生信息保存到文件中
3.修改和删除学生信息
4.查询学生信息
5.根据学生成绩进行排序
6.统计学生的总分
实现主函数:
编号 | 功能 |
0 | 退出系统 |
1 | 录入学生信息,调用insert()函数 |
2 | 查找学生信息,调用search()函数 |
3 | 删除学生信息,调用delete()函数 |
4 | 修改学生信息,调用modify()函数 |
5 | 对学生成绩排序,调用sort()函数 |
6 | 统计学生总人数,调用total()函数 |
7 | 显示所有的学生信息,调用show()函数 |
一、录入学生信息
- def insert():
- student_list = []
- while True:
- id = input("请输入学生id(如1001):")
- if not id: #判读空字符串;空字符串ASCII码值为False;
- break;
- name = input("请输入学生姓名:")
- if not name:
- break
- try:
- englist = int(input("请输入英语成绩:"))
- python = int(input("请输入python成绩:"))
- java = int(input("请输入Java成绩:"))
- except:
- print("成绩输入错误,请重新输入!")
- continue
- #录入学生信息
- student = {'id':id,'name':name,'englist':englist,'python':python,'java':java}
- student_list.append(student)
- answer = input("是否继续添加学生信息Y/N\n")
- if answer == 'Y' or answer == 'y':
- continue
- else:
- print("学生信息录入完毕!")
- break
- save(student_list)
- def save(lit):
- try:
- stu_txt = open(filename,'a',encoding="UTF-8")
- except:
- stu_txt = open(filename, 'w', encoding="UTF-8")
- for item in lit:
- stu_txt.write(str(item)+"\n")
- stu_txt.close()
二、表头与主函数
- def menum():
- print("===================学生信息管理系统=====================")
- print("---------------------功能菜单-------------------")
- print(" 1.录入学生信息")
- print(" 2.查找学生信息")
- print(" 3.删除学生信息")
- print(" 4.修改学生信息")
- print(" 5.排序")
- print(" 6.统计学生总人数")
- print(" 7.显示所有学生信息")
- print(" 0.退出系统")
- print("----------------------------------------------")
- def main():
- while True:
- menum()
- choice = int(input("请选择:"))
- if choice in [0,1,2,3,4,5,6,7]:
- if choice == 0:
- src = input("确定要退出系统吗:Y/N")
- if src == 'Y' or src == 'y':
- print("谢谢您使用!!")
- break
- else:
- continue
- elif choice == 1:
- insert()
- elif choice == 2:
- search()
- elif choice == 3:
- delete()
- elif choice == 4:
- modify()
- elif choice == 5:
- sort()
- elif choice == 6:
- total()
- elif choice == 7:
- show()
三、删除学生信息
- def delete():
- while True:
- student_id = input("请输入删除学生的ID:")
- if student_id != '':
- if os.path.exists(filename):#判断文件是否存在
- with open(filename,'r',encoding="UTF-8") as file:
- student_old = file.readlines()
- else:
- student_old = []
- flag = False
- if student_old:
- with open(filename,'w',encoding="UTF-8") as wfile:
- d = {}
- for item in student_old:
- d = dict(eval(item))#将字符串转化为字典
- if d['id'] != student_id:
- wfile.write(str(d)+"\n")#id相同的将不会写入;
- else:
- flag = True
- if flag :
- print(f'id为{student_id}的学生信息已删除')
- else:
- print(f'没有找到id为{student_id}的学生信息!!')
- else:
- print("没有学生信息!")
- break;
- show()
- answer = input("是否继续删除!")
- if answer == 'y' or answer == 'Y':
- continue
- else:
- break
四、修改学生信息
- def modify():
- show()
- if os.path.exists(filename):
- with open(filename,'r',encoding="UTF-8") as rfile:
- student_old = rfile.readlines()
- else:
- return
- student_id = input("请输入要修改学生的ID:")
- if student_id :
- with open(filename, 'w', encoding="UTF-8") as wfile:
- for item in student_old:
- d = dict(eval(item))
- if d['id'] == student_id:
- print('找到学生的相关信息可以进行修改!')
- while True:
- try:
- d['name'] = input("请输入姓名:")
- d['englist'] = input("请输入England成绩:")
- d['python'] = input("请输入python成绩:")
- d['java'] = input("请输入java成绩:")
- except:
- print("信息输入错误,请重新输入!!")
- else:
- break
- wfile.write(str(d)+"\n")
- print('修改成功~')
- else:
- wfile.write(str(d)+"\n")
- print('未找到修改学生的ID~~')
- answer = input("是否继续修改:")
- if answer == 'y' or answer == 'Y':
- modify()
- else:
- print('输入学生ID错误!')
五、查找学生信息
- def search():
- stuent_query = []
- while True:
- id = ''
- name = ''
- if os.path.exists(filename):
- mode = input("按学生ID查询选择:1,按学生姓名查询选择:2:")
- if mode == '1':
- id = input("请输入要查询学生的ID:")
- elif mode == '2':
- name = input("请输入要查询学生的姓名:")
- else:
- print("输入错误,请重新输入!!")
- search()
- with open(filename,'r',encoding="UTF-8") as rfile:
- stuent = rfile.readlines()
- for item in stuent:
- d = dict(eval(item))
- if id != '':
- if d['id'] == id:
- stuent_query.append(d)
- elif name != '':
- if d['name'] == name:
- stuent_query.append(d)
- pass
- show_student(stuent_query)
- stuent_query.clear()
- answer = input("是否继续查询学生:")
- if answer == 'y' or answer == 'Y':
- continue
- else:
- break
- else:
- print("暂未保存学生信息!!")
- return
学生信息输出格式化 函数
- def show_student(lst):
- if len(lst) == 0:
- print("没有查到学生信息,数据无法显示!!")
- return
- #标题结构定义
- format_tirle = '{:^6}\t{:^12}\t{:^8}\t{:^10}\t{:^10}\t{:^8}'
- print(format_tirle.format('ID','姓名','英语成绩','python成绩','java成绩','总成绩'))
- #显示内容格式
- format_data = '{:^6}\t{:^12}\t{:^8}\t{:^10}\t{:^10}\t{:^8}'
- for item in lst:
- print(format_data.format(item.get('id'),
- item.get('name'),
- item.get('englist'),
- item.get('python'),
- item.get('java'),
- int(item.get('englist'))+int(item.get('python'))+int(item.get('java'))))
六、学生成绩排序
- def sort():
- show()
- student_new = []
- if os.path.exists(filename):
- with open(filename,'r',encoding='UTF-8') as rfile:
- student = rfile.readlines()
- for item in student:
- d = dict(eval(item))
- student_new.append(d)
- else:
- print("暂无数据,无法输出!!")
- aesc_or = input('请选择排序方式(0:升序;1:降序)')
- if aesc_or == '0':
- aesc_or_bool = False
- elif aesc_or == '1':
- aesc_or_bool = True
- else:
- print("输入有误,请重新输入!!!")
- sort()
- mode = input('请选择排序方式(1.按英语排序 2.按python排序 3.按Java排序 0.按总成绩排序)')
- if mode == '1':
- student_new.sort(key= lambda x:int(x['englist']),reverse=aesc_or_bool)#lambda匿名函数;x代表字典每一项
- elif mode == '2':
- student_new.sort(key= lambda x:int(x['python']),reverse=aesc_or_bool)
- elif mode == '3':
- student_new.sort(key= lambda x:int(x['java']),reverse=aesc_or_bool)
- elif mode == '0':
- student_new.sort(key= lambda x:int(x['englist'])+int(x['java'])+int(x['python']),reverse=aesc_or_bool)
- else:
- print('输入错误!请重新输入!!')
- sort()
- show_student(student_new)
七、统计学生总人数
- def total():
- if os.path.exists(filename):
- with open(filename,'r',encoding='UTF-8') as rfile:
- student = rfile.readlines()
- if student:
- print(f'数据库中有{len(student)}名学生信息~')
- else:
- print("数据库中没有学生信息!!!")
- else:
- print('没有录入学生信息,数据无法输出!!')
八、显示所有学生
- student_list = []
- if os.path.exists(filename):
- with open(filename,'r',encoding='UTF-8') as rfile:
- student = rfile.readlines()
- for item in student:
- student_list.append(eval(item))
- if student_list:
- show_student(student_list)
- else:
- print("数据库中没有学生信息!!")
- else:
- print('暂时没有学生信息!!')
九、制作学生管理系统可执行文件
1.利用cmd命令导入:pip install PyInstaller模块安装
2.开始导入
【注】红线标注的就是导出可执行文件的地址
十、原文件
【注】可执行文件导入成功后,执行时,需要将student.txt与stusystem.exe文件放到同一个文件夹中;(原文件可以直接下载)
加油!还有什么好的想法可以私信;
——^0^
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。