当前位置:   article > 正文

Python学生管理系统

python学生管理系统

        随着高校的扩招,需要处理的学生信息日趋加大,不仅花费大量的教师资源,处理的
效率还十分低下。为提高学生管理的管理水平,优化资源,尽可能降低管理成本成为学生
管理的新课题,学生管理系统是从学生管理现状出发,根据学生管理的新要求进行开发设
计的,它解决了学生管理数据信息量大,修改不方便,对一系列数据进行分析时花费时间
长等问题,帮助学生管理人员有效管理学生信息,成为管理高校中必不可少的管理工具。

        学生管理系统具备的功能:

                1. 添加学生及成绩信息

                2.将学生信息保存到文件中

                3.修改和删除学生信息

                4.查询学生信息

                5.根据学生成绩进行排序

                6.统计学生的总分

        实现主函数:

编号功能
0退出系统
1录入学生信息,调用insert()函数
2查找学生信息,调用search()函数
3删除学生信息,调用delete()函数
4修改学生信息,调用modify()函数
5对学生成绩排序,调用sort()函数
6统计学生总人数,调用total()函数
7

显示所有的学生信息,调用show()函数

一、录入学生信息

  1. def insert():
  2. student_list = []
  3. while True:
  4. id = input("请输入学生id(如1001):")
  5. if not id: #判读空字符串;空字符串ASCII码值为False;
  6. break;
  7. name = input("请输入学生姓名:")
  8. if not name:
  9. break
  10. try:
  11. englist = int(input("请输入英语成绩:"))
  12. python = int(input("请输入python成绩:"))
  13. java = int(input("请输入Java成绩:"))
  14. except:
  15. print("成绩输入错误,请重新输入!")
  16. continue
  17. #录入学生信息
  18. student = {'id':id,'name':name,'englist':englist,'python':python,'java':java}
  19. student_list.append(student)
  20. answer = input("是否继续添加学生信息Y/N\n")
  21. if answer == 'Y' or answer == 'y':
  22. continue
  23. else:
  24. print("学生信息录入完毕!")
  25. break
  26. save(student_list)
  1. def save(lit):
  2. try:
  3. stu_txt = open(filename,'a',encoding="UTF-8")
  4. except:
  5. stu_txt = open(filename, 'w', encoding="UTF-8")
  6. for item in lit:
  7. stu_txt.write(str(item)+"\n")
  8. stu_txt.close()

二、表头与主函数

  1. def menum():
  2. print("===================学生信息管理系统=====================")
  3. print("---------------------功能菜单-------------------")
  4. print(" 1.录入学生信息")
  5. print(" 2.查找学生信息")
  6. print(" 3.删除学生信息")
  7. print(" 4.修改学生信息")
  8. print(" 5.排序")
  9. print(" 6.统计学生总人数")
  10. print(" 7.显示所有学生信息")
  11. print(" 0.退出系统")
  12. print("----------------------------------------------")
  1. def main():
  2. while True:
  3. menum()
  4. choice = int(input("请选择:"))
  5. if choice in [0,1,2,3,4,5,6,7]:
  6. if choice == 0:
  7. src = input("确定要退出系统吗:Y/N")
  8. if src == 'Y' or src == 'y':
  9. print("谢谢您使用!!")
  10. break
  11. else:
  12. continue
  13. elif choice == 1:
  14. insert()
  15. elif choice == 2:
  16. search()
  17. elif choice == 3:
  18. delete()
  19. elif choice == 4:
  20. modify()
  21. elif choice == 5:
  22. sort()
  23. elif choice == 6:
  24. total()
  25. elif choice == 7:
  26. show()

三、删除学生信息

  1. def delete():
  2. while True:
  3. student_id = input("请输入删除学生的ID:")
  4. if student_id != '':
  5. if os.path.exists(filename):#判断文件是否存在
  6. with open(filename,'r',encoding="UTF-8") as file:
  7. student_old = file.readlines()
  8. else:
  9. student_old = []
  10. flag = False
  11. if student_old:
  12. with open(filename,'w',encoding="UTF-8") as wfile:
  13. d = {}
  14. for item in student_old:
  15. d = dict(eval(item))#将字符串转化为字典
  16. if d['id'] != student_id:
  17. wfile.write(str(d)+"\n")#id相同的将不会写入;
  18. else:
  19. flag = True
  20. if flag :
  21. print(f'id为{student_id}的学生信息已删除')
  22. else:
  23. print(f'没有找到id为{student_id}的学生信息!!')
  24. else:
  25. print("没有学生信息!")
  26. break;
  27. show()
  28. answer = input("是否继续删除!")
  29. if answer == 'y' or answer == 'Y':
  30. continue
  31. else:
  32. break

四、修改学生信息

  1. def modify():
  2. show()
  3. if os.path.exists(filename):
  4. with open(filename,'r',encoding="UTF-8") as rfile:
  5. student_old = rfile.readlines()
  6. else:
  7. return
  8. student_id = input("请输入要修改学生的ID:")
  9. if student_id :
  10. with open(filename, 'w', encoding="UTF-8") as wfile:
  11. for item in student_old:
  12. d = dict(eval(item))
  13. if d['id'] == student_id:
  14. print('找到学生的相关信息可以进行修改!')
  15. while True:
  16. try:
  17. d['name'] = input("请输入姓名:")
  18. d['englist'] = input("请输入England成绩:")
  19. d['python'] = input("请输入python成绩:")
  20. d['java'] = input("请输入java成绩:")
  21. except:
  22. print("信息输入错误,请重新输入!!")
  23. else:
  24. break
  25. wfile.write(str(d)+"\n")
  26. print('修改成功~')
  27. else:
  28. wfile.write(str(d)+"\n")
  29. print('未找到修改学生的ID~~')
  30. answer = input("是否继续修改:")
  31. if answer == 'y' or answer == 'Y':
  32. modify()
  33. else:
  34. print('输入学生ID错误!')

五、查找学生信息

  1. def search():
  2. stuent_query = []
  3. while True:
  4. id = ''
  5. name = ''
  6. if os.path.exists(filename):
  7. mode = input("按学生ID查询选择:1,按学生姓名查询选择:2:")
  8. if mode == '1':
  9. id = input("请输入要查询学生的ID:")
  10. elif mode == '2':
  11. name = input("请输入要查询学生的姓名:")
  12. else:
  13. print("输入错误,请重新输入!!")
  14. search()
  15. with open(filename,'r',encoding="UTF-8") as rfile:
  16. stuent = rfile.readlines()
  17. for item in stuent:
  18. d = dict(eval(item))
  19. if id != '':
  20. if d['id'] == id:
  21. stuent_query.append(d)
  22. elif name != '':
  23. if d['name'] == name:
  24. stuent_query.append(d)
  25. pass
  26. show_student(stuent_query)
  27. stuent_query.clear()
  28. answer = input("是否继续查询学生:")
  29. if answer == 'y' or answer == 'Y':
  30. continue
  31. else:
  32. break
  33. else:
  34. print("暂未保存学生信息!!")
  35. return

学生信息输出格式化 函数

  1. def show_student(lst):
  2. if len(lst) == 0:
  3. print("没有查到学生信息,数据无法显示!!")
  4. return
  5. #标题结构定义
  6. format_tirle = '{:^6}\t{:^12}\t{:^8}\t{:^10}\t{:^10}\t{:^8}'
  7. print(format_tirle.format('ID','姓名','英语成绩','python成绩','java成绩','总成绩'))
  8. #显示内容格式
  9. format_data = '{:^6}\t{:^12}\t{:^8}\t{:^10}\t{:^10}\t{:^8}'
  10. for item in lst:
  11. print(format_data.format(item.get('id'),
  12. item.get('name'),
  13. item.get('englist'),
  14. item.get('python'),
  15. item.get('java'),
  16. int(item.get('englist'))+int(item.get('python'))+int(item.get('java'))))

六、学生成绩排序

  1. def sort():
  2. show()
  3. student_new = []
  4. if os.path.exists(filename):
  5. with open(filename,'r',encoding='UTF-8') as rfile:
  6. student = rfile.readlines()
  7. for item in student:
  8. d = dict(eval(item))
  9. student_new.append(d)
  10. else:
  11. print("暂无数据,无法输出!!")
  12. aesc_or = input('请选择排序方式(0:升序;1:降序)')
  13. if aesc_or == '0':
  14. aesc_or_bool = False
  15. elif aesc_or == '1':
  16. aesc_or_bool = True
  17. else:
  18. print("输入有误,请重新输入!!!")
  19. sort()
  20. mode = input('请选择排序方式(1.按英语排序 2.按python排序 3.按Java排序 0.按总成绩排序)')
  21. if mode == '1':
  22. student_new.sort(key= lambda x:int(x['englist']),reverse=aesc_or_bool)#lambda匿名函数;x代表字典每一项
  23. elif mode == '2':
  24. student_new.sort(key= lambda x:int(x['python']),reverse=aesc_or_bool)
  25. elif mode == '3':
  26. student_new.sort(key= lambda x:int(x['java']),reverse=aesc_or_bool)
  27. elif mode == '0':
  28. student_new.sort(key= lambda x:int(x['englist'])+int(x['java'])+int(x['python']),reverse=aesc_or_bool)
  29. else:
  30. print('输入错误!请重新输入!!')
  31. sort()
  32. show_student(student_new)

七、统计学生总人数

  1. def total():
  2. if os.path.exists(filename):
  3. with open(filename,'r',encoding='UTF-8') as rfile:
  4. student = rfile.readlines()
  5. if student:
  6. print(f'数据库中有{len(student)}名学生信息~')
  7. else:
  8. print("数据库中没有学生信息!!!")
  9. else:
  10. print('没有录入学生信息,数据无法输出!!')

八、显示所有学生

  1. student_list = []
  2. if os.path.exists(filename):
  3. with open(filename,'r',encoding='UTF-8') as rfile:
  4. student = rfile.readlines()
  5. for item in student:
  6. student_list.append(eval(item))
  7. if student_list:
  8. show_student(student_list)
  9. else:
  10. print("数据库中没有学生信息!!")
  11. else:
  12. print('暂时没有学生信息!!')

九、制作学生管理系统可执行文件

        1.利用cmd命令导入:pip install PyInstaller模块安装

         2.开始导入

         【注】红线标注的就是导出可执行文件的地址

十、原文件

student.txt

stusystem.py

stusystem.exe

【注】可执行文件导入成功后,执行时,需要将student.txt与stusystem.exe文件放到同一个文件夹中;(原文件可以直接下载)

                        加油!还有什么好的想法可以私信;

                                        ——^0^

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/Gausst松鼠会/article/detail/170304
推荐阅读
相关标签
  

闽ICP备14008679号