这是我参与11月更文挑战的第4天,活动详情查看:2021最后一次更文挑战
简介
前三次介绍了学生管理系统的功能模块分布,分别介绍了如何录入学生信息,修改学生信息,删除学生信息,以及如何展示学生信息。本次文章主要是介绍如何查找学生信息,并且将学生信息进行一些简单的排序,比如按照学号排序或者成绩等信息进行排序。
查找学生信息功能模块
如何实现查找学生信息模块功能:
首先定义一个列表文件,防止重名的出现。然后在控制台获取输入的学生ID,将学生ID的信息与磁盘文件中的信息进行对比,看看是否可以找到对应的学生信息,如果找到对应的学生信息,则根据对应的格式进行输出,并清空列表。若没有找到对应的学生信息,则显示输入错误,请重新输入。
具体实现:
- 编写主函数中调用的查找学生信息的函数search()
def search(): # 查找学生信息
student_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:
student = rfile.readlines()
for item in student:
d = dict(eval(item))
if id != '':
if d['id'] == id:
student_query.append(d)
elif name != '':
if d['name'] == name:
student_query.append(d)
# 显示查询结果
show_student(student_query)
# 清空列表
student_query.clear()
answer = input('是否继续查询?y/n')
if answer == 'y' or answer == 'Y':
continue
else:
break
else:
print('暂未保存学生信息')
return
- 定义显示查询结果的函数show_student(query student)
def show_student(lst):
if len(lst) == 0:
print('没有查到学生信息,无数据显示!!!')
return
# 定义标题显示格式
format_title = '{:^6}\t{:^10}\t{:^8}\t{:^10}\t{:^8}\t{:^8}' # 格式化字符串的形式
print(format_title.format('ID', '姓名', '英语成绩', 'python成绩', 'java成绩', '总成绩'))
# 定义内容的显示格式
format_data = '{:^6}\t{:^10}\t{:^8}\t{:^10}\t{:^8}\t{:^8}'
for item in lst:
print(format_data.format(item.get('id'),
item.get('name'),
item.get('english'),
item.get('python'),
item.get('java'),
int(item.get('english')) + int(item.get('python')) + int(item.get('java'))))
查询学生总人数模块
如何实现查询学生总人数功能
首先判断文件是否存在,统计学生信息文件中保存的学生信息个数,实际就是判断列表的长度。
具体实现
编写主函数中调用的统计学生总人数的函数total()
def total(): # 统计学生总人数
if os.path.exists(filename): # 判断文件是否存在
with open(filename, 'r', encoding='utf-8') as rfile:
students = rfile.readlines()
if students:
print(f'一共有{len(students)}名学生')
else:
print('还没有录入学生信息')
else:
print('暂未保存数据.........')
排序模块
如何实现排序功能
本文主要是介绍如何通过学生成绩,对学生信息进行排序,主要对学生信息按英语成绩、python成绩、java成绩和总成绩进行升序或者降序进行排序。首先,读取磁盘文件的信息,然后选择升序还是降序,然后在对学生信息进行排序。
具体实现
编写主函数中调用的排序函数sort()
def sort(): # 排序
show()
if os.path.exists(filename):
with open(filename, 'r', encoding='utf-8') as rfile:
student_list = rfile.readlines()
student_new = []
for item in student_list:
d = dict(eval(item))
student_new.append(d)
else:
return
asc_or_desc = input('请选择(0是升序,1是降序):')
if asc_or_desc == '0':
asc_or_desc_bool = False
elif asc_or_desc == '1':
asc_or_desc = True
else:
print('您输入的有误,请重新输入:')
sort()
mode = input('请选择排序方式(1.按照英语排序,2.按照python排序,3.按照java排序,4.按照总成绩排序):')
if mode == '1':
student_new.sort(key=lambda x: int(x['english']), reverse=asc_or_desc_bool) # lambda匿名函数
elif mode == '2':
student_new.sort(key=lambda x: int(x['python']), reverse=asc_or_desc_bool)
elif mode == '3':
student_new.sort(key=lambda x: int(x['java']), reverse=asc_or_desc_bool)
elif mode == '4':
student_new.sort(key=lambda x: int(x['english'] + int(x['java']) + int(x['python'])), reverse=asc_or_desc_bool)
else:
print('您的输入有误请重新输入')
sort()
show_student(student_new)
总结
到此为止,学生管理系统的大框架已经搭建完毕,剩下的就是如何实现,下一章会介绍如何实现代码的运行,以及部分调试功能,希望对大家有所帮助。
今天的文章学生管理系统(4)分享到此就结束了,感谢您的阅读。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/14335.html