学生信息管理系统
一、学生管理系统应具备的功能
1、添加学生及成绩信息 2、将学生信息保存到文件中 3、修改和删除学生信息 4、查询学生信息
5、根据学生成绩进行排序 6、统计学生的总分
二、系统设计
(1)学生信息管理系统的7大模块
1、录入学生信息模块 2、查找学生信息模块 3、删除学生信息模块 4、修改学生信息模块 5、学生成绩排名模块 6、统计学生总人数模块 7、显示全部学生信息模块
(2)系统业务流程
(3)项目目录结构
三、主函数设计
1、系统主界面运行效果
2、主函数的业务流程
3、实现主函数
编号 | 功能 |
0 | 退出系统 |
1 | 录入学生信息,调用insert()函数 |
2 | 查找学生信息,调用search()函数 |
3 | 删除学生信息,调用delete()函数 |
4 | 修改学生信息,调用modify()函数 |
5 | 对学生成绩排序,调用sort()函数 |
6 | 统计学生总人数,调用total()函数 |
7 | 显示所有的学生信息,调用show()函数 |
4、程序代码
def main():
while True:
menm()
choice=int(input('请选择: '))
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 menm():
print('==================学生信息管理系统==================')
print('---------------------功能菜单----------------------')
print('\t\t\t\t\t\t1.录入学生信息')
print('\t\t\t\t\t\t2.查找学生信息')
print('\t\t\t\t\t\t3.删除学生信息')
print('\t\t\t\t\t\t4.修改学生信息')
print('\t\t\t\t\t\t5.排序')
print('\t\t\t\t\t\t6.统计学生总人数')
print('\t\t\t\t\t\t7.显示所有学生信息')
print('\t\t\t\t\t\t0.退出系统')
def insert():
pass
def search():
pass
def delete():
pass
def modify():
pass
def sort():
pass
def total():
pass
def show():
pass
四、录入学生信息功能
从控制台录入学生信息,并且把它们保存到磁盘文件中
1、业务流程
2、功能具体实现
save(student)函数,用于将学生信息保存到文件
insert()函数,用于录入学生信息
3、程序代码
def insert():
student_list=[]
while True:
id=input('请输入ID(如1001): ')
if not id:
break
name=input('请输入姓名: ')
if not name:
break
try:
english=int(input('请输入英语成绩: '))
python=int(input('请输入Python成绩: '))
java=int(input('请输入Java成绩: '))
except:
print('输入无效,不是整数型,请重新输入')
continue
student={'id':id, 'name':name, 'english':english, 'python':python, 'java':java}
student_list.append(student)
answer=input('是否继续添加?y/n\n')
if answer=='y':
continue
else:
break
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()
五、查找学生信息功能
从控制台录入学生ID或姓名,到磁盘文件中找到对应的学生信息
1、业务流程
2、功能具体实现
编写主函数中调用的查找学生信息的函数search()
定义显示查询结果的函数show_student(query_student)
3、程序代码
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('pyrhon'),
item.get('java'),
int(item.get('english')+int(item.get('python')+int(item.get('java'))))
六、删除学生信息功能
从控制台录入学生ID,到磁盘文件中找到对应的学生信息,并将其删除
1、业务流程
2、功能具体实现
编写主函数中调用的删除学生信息的函数delete()
调用了show()函数显示学生信息,该函数的功能将在后面完成
3、程序代码
import os
def delete():
while True:
student_id=input('请输入要删除的学生的ID: ')
if student_id !='':
if os.path.exists(filename):
with open(filename, 'r', encoding='UTF-8'):
student_old=filename.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('是否继续删除?y/n\n')
if answer=='y':
continue
else:
break
七、修改学生信息功能
从控制台录入学生ID,到磁盘文件中找到对应的学生信息,将其进行修改
1、业务流程
2、功能具体实现
编写主函数中调用的修改学生信息的函数modify()
调用了show()函数显示学生信息,该函数的功能将在后面完成
3、程序代码
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()
八、排序
主要对学生信息按英语成绩、python成绩、Java成绩、总成绩进行升序或降序排序
1、业务流程
2、 程序代码
def sort():
show()
if os.path.exists(filename):
with open(filename, 'r', encoding='UTF-8') as rfile:
student_lst=rfile.readlines()
student_new=[]
for item in student_lst:
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_bool=True
else:
print('您的输入有误,请重新输入!')
sort()
mode=input('请选择排序方式(1.按英语成绩排序 2.按python成绩排序 3.按Java成绩排序 0.按总成绩排序): ')
if mode=='1':
student_new.sort(key=lambda x :int(x['english']), reverse=asc_or_desc_bool)
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=='0':
student_new.sort(key=lambda x :int(x['english'])+int(x['python'])+int(x['java']), reverse=asc_or_desc_bool)
else:
print('您的输入有误,请重新输入!')
sort()
show_student(student_new)
九、统计学生总人数功能
统计学生信息文件中保存的学生信息个数
1、业务流程
2、程序代码
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('暂未保存数据信息')
十、显示所有学生信息
将学生信息文件中保存的全部学生信息获取并显示
1、业务流程
2、程序代码
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)
else:
print('暂未保存过数据!')