学生成绩管理系统主要包括录入学生信息、查找学生信息、删除学生信息、修改学生信息、排序、统计学生总人数、显示学生信息和退出系统。
系统界面编写(菜单显示函数):
def menu():
print('============学生信息管理系统============')
print('---------------功能菜单---------------')
print('\t\t\t1.录入学生信息')
print('\t\t\t2.查找学生信息')
print('\t\t\t3.删除学生信息')
print('\t\t\t4.修改学生信息')
print('\t\t\t5.排序')
print('\t\t\t6.统计学生总人数')
print('\t\t\t7.显示所有学生信息')
print('\t\t\t0.退出系统')
print('-------------------------------------')
main函数:
def main():
while(True):
menu()
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 insert():
stu_list=[]
while True:
id=input('请输入学生ID(如1001):')
if not id:
break
name=input('请输入学生姓名:')
if not name:
break
try:
english=int(input('请输入英语成绩:'))
java=int(input('请输入java成绩:'))
python=int(input('请输入python成绩:'))
except:
print('输入无效,不是整数,请重新输入:')
continue
#将录入的学生成绩保存到字典中
student={'id':id,'name':name,'English':english,'Java':java,'Python':python}
#将学生信息添加到列表中
stu_list.append(student)
answer=input('是否继续添加(Y/N):')
if answer == 'y' or answer == 'Y':
continue
else:
break
#调用save()函数保存在文件中
save(stu_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 search():
student_query=[]
while True:
id=''
name=''
if os.path.exists(filename):
mod=input('若根据ID查找学生信息,请输入1;若根据姓名查找学生信息,请输入2:')
if mod=='1':
id=input('请输入学生ID:')
elif mod=='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' or 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{:^10}'
print(format_title.format('ID','Name','English','Java','Python','Grade'))
# 定义内容的显示格式
format_data='{:^6}\t{:^12}\t{:^8}\t{:^10}\t{:^10}\t{:^10}'
for item in lst:
print(format_data.format(item.get('id'),
item.get('name'),
item.get('English'),
item.get('Java'),
item.get('Python'),
int(item.get('English'))+int(item.get('Java'))+int(item.get('Python'))
))
删除学生信息函数:
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('是否继续删除?(Y/N):')
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:')
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['Java']=input('请输入java成绩:')
d['Python']=input('请输入python成绩:')
except:
print('输入有误,请重新输入')
else:
break
wfile.write(str(d)+'\n')
print('修改成功!')
else:
wfile.write(str(d) + '\n')
answer=input('是否继续修改?(Y/N):')
if answer=='y' or answer =='Y':
modify()
排序函数:
def sort():
show()
student_list=[]
asc_or_desc=input('请选择排序方式(0为升序,1为降序):')
mode=input('请选择排序依据(1为按英语成绩排序,2为按Java成绩排序,3为按Python成绩排序,0为按总成绩排序):')
if os.path.exists(filename):
with open(filename,'r',encoding='utf-8')as rfile:
students=rfile.readlines()
for item in students:
d=dict(eval(item))
student_list.append(d)
else:
print('暂未保存学生信息!')
return
if asc_or_desc=='0':
asc_or_desc_bool=False
elif asc_or_desc=='1':
asc_or_desc_bool=True
else:
print('输入有误,请重新输入:')
sort()
if mode=='1':
student_list.sort(key=lambda x:int(x['English']),reverse=asc_or_desc_bool) #使用匿名函数lambda
elif mode=='2':
student_list.sort(key=lambda x:int(x['Java']), reverse=asc_or_desc_bool)
elif mode=='3':
student_list.sort(key=lambda x:int(x['Python']), reverse=asc_or_desc_bool)
elif mode=='0':
student_list.sort(key=lambda x:int(x['English'])+int(x['Java'])+int(x['Python']), reverse=asc_or_desc_bool)
else:
print('输入有误,请重新输入!')
sort()
show_student(student_list)
统计学生总人数函数:
def total():
if os.path.exists(filename):
with open(filename,'r',encoding='utf-8')as rfile:
students=rfile.readlines()
if students==[]:
print('暂未录入学生信息,请先录入!')
return
else:
print(f'共有{len(students)}名学生!')
else:
print('暂未保存学生信息!!!')
return
显示学生信息函数:
def show():
student_list=[]
if os.path.exists(filename):
with open(filename,'r',encoding='utf-8')as rfile:
student_l=rfile.readlines()
for item in student_l:
student_list.append(eval(item)) #eval还原为字典类型
if student_list:
show_student(student_list)
else:
print('暂未保存学生信息!')
return
执行:
if __name__ == '__main__': # 只有执行该程序时,才会执行 import 是不可以执行的
main()
完整源代码:
filename='student.txt'
import os
def main():
while(True):
menu()
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 menu():
print('============学生信息管理系统============')
print('---------------功能菜单---------------')
print('\t\t\t1.录入学生信息')
print('\t\t\t2.查找学生信息')
print('\t\t\t3.删除学生信息')
print('\t\t\t4.修改学生信息')
print('\t\t\t5.排序')
print('\t\t\t6.统计学生总人数')
print('\t\t\t7.显示所有学生信息')
print('\t\t\t0.退出系统')
print('-------------------------------------')
def insert():
stu_list=[]
while True:
id=input('请输入学生ID(如1001):')
if not id:
break
name=input('请输入学生姓名:')
if not name:
break
try:
english=int(input('请输入英语成绩:'))
java=int(input('请输入java成绩:'))
python=int(input('请输入python成绩:'))
except:
print('输入无效,不是整数,请重新输入:')
continue
#将录入的学生成绩保存到字典中
student={'id':id,'name':name,'English':english,'Java':java,'Python':python}
#将学生信息添加到列表中
stu_list.append(student)
answer=input('是否继续添加(Y/N):')
if answer == 'y' or answer == 'Y':
continue
else:
break
#调用save()函数保存在文件中
save(stu_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 search():
student_query=[]
while True:
id=''
name=''
if os.path.exists(filename):
mod=input('若根据ID查找学生信息,请输入1;若根据姓名查找学生信息,请输入2:')
if mod=='1':
id=input('请输入学生ID:')
elif mod=='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' or 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{:^10}'
print(format_title.format('ID','Name','English','Java','Python','Grade'))
# 定义内容的显示格式
format_data='{:^6}\t{:^12}\t{:^8}\t{:^10}\t{:^10}\t{:^10}'
for item in lst:
print(format_data.format(item.get('id'),
item.get('name'),
item.get('English'),
item.get('Java'),
item.get('Python'),
int(item.get('English'))+int(item.get('Java'))+int(item.get('Python'))
))
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('是否继续删除?(Y/N):')
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:')
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['Java']=input('请输入java成绩:')
d['Python']=input('请输入python成绩:')
except:
print('输入有误,请重新输入')
else:
break
wfile.write(str(d)+'\n')
print('修改成功!')
else:
wfile.write(str(d) + '\n')
answer=input('是否继续修改?(Y/N):')
if answer=='y' or answer =='Y':
modify()
def sort():
show()
student_list=[]
asc_or_desc=input('请选择排序方式(0为升序,1为降序):')
mode=input('请选择排序依据(1为按英语成绩排序,2为按Java成绩排序,3为按Python成绩排序,0为按总成绩排序):')
if os.path.exists(filename):
with open(filename,'r',encoding='utf-8')as rfile:
students=rfile.readlines()
for item in students:
d=dict(eval(item))
student_list.append(d)
else:
print('暂未保存学生信息!')
return
if asc_or_desc=='0':
asc_or_desc_bool=False
elif asc_or_desc=='1':
asc_or_desc_bool=True
else:
print('输入有误,请重新输入:')
sort()
if mode=='1':
student_list.sort(key=lambda x:int(x['English']),reverse=asc_or_desc_bool) #使用匿名函数lambda
elif mode=='2':
student_list.sort(key=lambda x:int(x['Java']), reverse=asc_or_desc_bool)
elif mode=='3':
student_list.sort(key=lambda x:int(x['Python']), reverse=asc_or_desc_bool)
elif mode=='0':
student_list.sort(key=lambda x:int(x['English'])+int(x['Java'])+int(x['Python']), reverse=asc_or_desc_bool)
else:
print('输入有误,请重新输入!')
sort()
show_student(student_list)
def total():
if os.path.exists(filename):
with open(filename,'r',encoding='utf-8')as rfile:
students=rfile.readlines()
if students==[]:
print('暂未录入学生信息,请先录入!')
return
else:
print(f'共有{len(students)}名学生!')
else:
print('暂未保存学生信息!!!')
return
def show():
student_list=[]
if os.path.exists(filename):
with open(filename,'r',encoding='utf-8')as rfile:
student_l=rfile.readlines()
for item in student_l:
student_list.append(eval(item)) #eval还原为字典类型
if student_list:
show_student(student_list)
else:
print('暂未保存学生信息!')
return
if __name__ == '__main__': # 只有执行该程序时,才会执行 import 是不可以执行的
main()
运行结果:
录入信息截图:
查询信息截图:
统计学生总人数截图: