1.需求分析
- 学生管理系统应具备的功能
- 添加学生及成绩信息
- 将学生信息保存到文件中
- 修改和删除学生信息
- 查询学生信息
- 根据学生成绩进行排序
- ·统计学生的总分
2.系统设计
- 系统功能结构
- 学生信息管理系统的7大模块
- 录入学生信息模块
- 查找学生信息模块
- 删除学生信息模块
- 学生成绩排名模块
- 统计学生总人数模块
- 显示全部学生信息模块
-系统业务流程
- 学生信息管理系统的7大模块
3.系统开发必备
- 系统开发环境
- 操作系统:win 10
- Python解释器版本:Python3.8
- 开发工具:PyCharm
- Python内置模块:os,re
- 项目目录结构
4.主函数设计
- 系统主界面效果图
- 主函数的业务流程
- 实现主函数
stusystem.py
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':
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\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.退出')
print('-------------------------------------------------------------------------')
def insert():
pass
def search():
pass
def delete():
pass
def modify():
pass
def sort():
pass
def total():
pass
def show():
pass
if __name__ == '__main__':
main()
5.学生信息维护模块设计
- 实现录入学生信息功能
*从控制台录入学生信息,并且把它们保存到磁盘文件中
运行效果:
业务流程:
- 具体实现
*save(student)函数,用于将学生信息保存到文件
*insert()函数,用于录入学生信息
代码:
def insert():
lis=[]
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
#将录入的学生信息保存到字典中
lis1={'id':id,'name':name,'english':english,'python':python,'java':java}
#将学生信息添加到列表中
lis.append(lis1)
answer=input('是否继续添加?y/n')
if answer=='y':
continue
else:
break
#调用sava()函数,保存列表中的内容
save(lis)
print('学生信息已录入完毕!')
def save(l):
try:
stu_txt=open(filename,'a',encoding='utf-8')
except:
stu_txt=open(filename,'w',encoding='utf-8')
for item in l:
stu_txt.write(str(item)+'\n')
stu_txt.close()
-
实现删除学生信息功能
*从控制台录入学生ID,到磁盘文件中找到对应的学生信息,并将其删除- 运行效果图:
- 业务流程图
- 运行效果图:
-
具体实现
- 编写主函数中调用的删除学生信息的函数delete()
- 调用了show()函数显示学生信息,该函数的功能将在后面完成
def delete():
while True:
stu_id=input('请输入要删除的学生ID:')
if stu_id!='': #判断stu_id是否输入了ID
if os.path.exists(filename): #判断磁盘上有没有filename这个文件,判断这个文件是否存在
with open(filename,'r',encoding='utf-8') as file:
stu_old=file.readlines()
else:
stu_old=[]
flag=False #用来标记数据是否删除
if stu_old:
with open(filename,'w',encoding='utf-8') as wfile:
d={} #将删除数据之后的字典存进磁盘文件中
for item in stu_old:
d=dict(eval(item)) #将字符串类型转成字典
if d['id']!=stu_id:
wfile.write(str(d)+'\n')
else:
flag=True
if flag:
print(f'id为{stu_id}的学生信息已被删除') #格式化字符串
else:
print(f'没有找到id为{stu_id}的学生信息')
else:
print('无学生信息!')
break
show() #重新显示学生信息
answer=input('是否继续删除?y/n')
if answer=='y':
continue
else:
break
- 实现修改学生信息功能
*从控制台录入学生ID,到磁盘文件中找到对应的学生信息,将其进行修改
业务流程图- 具体实现
- 编写主函数中调用的修改学生信息的函数modify()
- 调用了show()函数显示学生信息,该函数的功能将在后面完成
- 具体实现
def modify():
show()
if os.path.exists(filename):
with open(filename,'r',encoding='utf-8') as rfile:
stu_old=rfile.readlines()
else:
return
student_id=input('请输入要修改的学员ID:')
if student_id !='':
with open(filename,'w',encoding='utf-8') as wfile:
for item in stu_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')
if answer=='y':
modify()
## 6.查询/统计模块设计
- 实现查询学生信息功能
* 从控制台录入学生ID或姓名,到磁盘文件中找到对应的学生信息
* 具体实现
+ 编写主函数中调用的查找学生信息的函数search()
+ 定义显示查询结果的函数show_student(query_student)
```python
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{:^8}\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:
student=rfile.readlines()
if student:
print(f'一共有{len(student)}名学生')
else:
print('还没有录入学生信息')
else:
print('暂未保存数据信息...')
- 查询/统计模块设计-显示所有学生信息功能
- 实现显示所有学生信息功能
+将学生信息文件中保存的全部学生信息获取并显示
- 实现显示所有学生信息功能
def show():
student_lst=[]
if os.path.exists(filename):
with open(filename,'r',encoding='utf-8') as rfile:
student=rfile.readlines()
for item in student:
student_lst.append(eval(item))
if student_lst:
show_student(student_lst)
else:
print('暂未保存过数据')
7.排序模块设计
- 排序模块设计
- 实现按学生成绩排序功能
- 主要对学生信息按英语成绩、Python 成绩、Java成绩、总成绩进行升序或降序
- 主要对学生信息按英语成绩、Python 成绩、Java成绩、总成绩进行升序或降序
- 具体实现
- 编写主函数中调用的排序函数sort()
- 实现按学生成绩排序功能
def sort():
show()
student_new=[]
if os.path.exists(filename):
with open(filename,'r',encoding='utf-8') as rfile:
student=rfile.readlines()
for item in student:
student_new.append(dict(eval(item)))
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)
7.项目打包
- 安装第三方模块(即使电脑上没有安装Python软件,也可以用exe方式运行)
- 在线安装方式(打开cmd)
- pip install PyInstaller
- 执行打包操作
- 在线安装方式(打开cmd)
pyinstaller -F E:\pythoncode\代码练习\chap17\stusystem.py
#-F:只生成一个扩展名为.exe的可执行文件