Python的学习(十七):学生信息管理系统
需求分析
- 应该具备的功能
- 添加学生及成绩信息
- 将学生信息保存到文件中
- 修改和删除学生信息
- 查询学生信息
- 根据学生成绩进行排序
- 统计学生的总分
系统设计
- 系统管理的7大模块
- 录入学生信息模块
- 查找学生信息模块
- 删除学生信息模块
- 修改学生信息模块
- 学生成绩排名模块
- 统计学生总人数模块
- 显示全部学生信息模块
-
系统业务流程
主函数设计
编号 | 功能 |
---|---|
0 | 退出系统 |
1 | 录入学生信息,调用insert()函数 |
2 | 查找学生信息,调用search()函数 |
3 | 删除学生信息,调用delete()函数 |
4 | 修改学生信息,调用modify()函数 |
5 | 对学生成绩进行排序,调用sort()函数 |
6 | 统计学生总人数,调用total()函数 |
7 | 显示所有学生信息,调用show()函数 |
def main():
while True:
menu()
choice = int(input('请输入你想要的选择:'))#将输入的字符转为int
if choice in [0,1,2,3,4,5,6,7]:
if choice == 0:
answer = input('您确定要退出系统吗?y/n')
if answer == 'y' or answer == '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 menu():
print('=========================学生信息管理系统===========================')
print('---------------------------功能菜单-------------------------------')
print('\t\t\t\t\t\t\t0.退出系统')
print('\t\t\t\t\t\t\t1.录入信息')
print('\t\t\t\t\t\t\t2.查找信息')
print('\t\t\t\t\t\t\t3.删除信息')
print('\t\t\t\t\t\t\t4.修改信息')
print('\t\t\t\t\t\t\t5.信息排序')
print('\t\t\t\t\t\t\t6.统计人数')
print('\t\t\t\t\t\t\t7.显示信息')
print('----------------------------------------------------------------')
录入学生信息
def insert():
student_list = []
while True:
id = input('请输入ID(如1001):')
if not id:
break
name = input('请输入姓名:')
if not name:
break
try:
englight = int(input('请输入英语成绩:'))
python = int(input('请输入Python成绩:'))
java = int(input('请输入java成绩:'))
except:
print('输入无效,不是有效整数类型,请重新输入')
continue
#将录入的学生信息保存到字典
student = {'id':id,'name':name,'english':englight,'python':python,'java':java}
#将学生信息添加到列表中
student_list.append(student)
answer = input('是否继续添加?y/n\n')
if answer == 'y':
continue
else:
break
#调用save方法,保存信息到文件中
save(student_list)
print('学生信息录入完毕!!!')
def save(lst):
try:
stu_txt = open(filename,'a',encoding='utf-8')
except:
stu_txt = open(filename,'w',encoding='utf-8')
for item in lst:
stu_txt.write(str(item)+'\n')
stu_txt.close()
删除学生信息
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')
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':
continue
else:
break
修改学生信息功能
- 从控制台录入学生Id,到磁盘中找到对应的学生信息,将其进行修改。
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:')
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['english'] = input('请输入英语成绩:')
d['python'] = input('请输入Python的成绩:')
d['java'] = input('请输入java成绩:')
except:
print('您的输入有误,请重新输入!!!')
else:
break
wfile.write(str(d) + '\n')
print('修改成功!!!')
else:
wfile.write(str(d)+'\n')
answer = input('是否继续修改其他学生信息?y/n\n')
if answer == 'y':
modify()
查找功能
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\n')
if answer == 'y':
continue
else:
break
else:
print('暂未保存学生信息')
return
def show_student(lst):
if len(lst) == 0:
print('没有查询到学生的信息,无数据显示!')
return
#定义显示标题格式
format_title = '{:^6}\t{:^12}\t{:^8}\t{:^10}\t{:^10}\t{:^8}'
print(format_title.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('english'),
item.get('python'),
item.get('java'),
int(item.get('english'))+int(item.get('python'))+int(item.get('java'))
))
统计学生个数
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('暂未保存数据信息......')
显示所有信息
def show():
student_lst = []
if os.path.exists(filename):
with open(filename,'r',encoding='utf-8') as rfile:
students = rfile.readlines()
for item in students:
student_lst.append(eval(item))
if student_lst:
show_student(student_lst)
排序
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
as_or_desc = input('请选择升序0或者降序1:')
if as_or_desc == '0':
as_or_desc_bool = False
elif as_or_desc == '1':
as_or_desc_bool = True
else:
print('您的输入有误,请重新输入')
sort()
mode = input('请选择排序方式:1.英语2.python3.java0.总成绩')
if mode == '1':
student_new.sort(key=lambda x:int(x['english']),reverse=as_or_desc_bool)
elif mode == '2':
student_new.sort(key=lambda x:int(x['python']),reverse=as_or_desc_bool)
elif mode == '3':
student_new.sort(key=lambda x:int(x['java']),reverse=as_or_desc_bool)
elif mode == '0':
student_new.sort(key=lambda x:int(x['english'])+int(x['python'])+int(x['java']),reverse=as_or_desc_bool)
else:
print('您的输入有误请重新输入:')
sort()
show_student(student_new)