学生信息管理系统
前言
免责声明:
本博文的初衷是分享自己学习Python尝试做项目的一些感悟,所涉及的内容仅供学习、交流,请勿将其用于非法用途!!!任何由此引发的法律纠纷均与作者本人无关,请自行负责!!!
版权声明:
未经作者本人授权,禁止转载!!!
一、框架思考
1.添加学生个人信息(包括个人信息、成绩)
2.修改、删除学生信息
3.查询学生信息
4.根据成绩对学生排名
二、主要功能函数介绍
1.添加函数insert()
insert()函数主要用于首次登陆管理系统时录入学生信息
函数代码如下:
def insert():
stdentList = [] # 创建学生信息表为空的列表
mark = True
while mark:
id = input("请输入ID(如242560):").strip() # 用户输入学生ID,这里通过strip()去掉空格
if not id:
break
name = input("请输入名字:").strip() # 输入名字,同样去掉空格
if not name: # 如果没有名字,循环结束
break
try:
chinese = int(input("请输入语文成绩:")) # 输入语文成绩
maths = int(input("请输入数学成绩:")) # 输入数学成绩
english = int(input("请输入英语成绩")) # 输入英语成绩
except:
print("输入无效,不是整数。。。。。。重新输入!")
continue # 输入无效内容将不会被存储
# 将学生信息保存到字典
stdent = {'id': id, 'name': name, 'chinese': chinese, 'maths': maths, 'english': english}
stdentList.append(stdent) #将学生成绩以字典的形式添加到stdentList空列表中
inputMark = input("是否继续添加? (y/n):")
if inputMark == "y":
mark = True
else:
mark = False
save(stdentList)
print("学生信息录入完毕!!!")
2.查询函数search()
search()函数主要用于在录入学生信息之后通过搜索信息查询学生信息
函数代码如下:
def search():
mark = True
student_query = []
while mark:
id = "" # 定义ID为空
name = "" # 定义名字为空
if os.path.exists(filename): # 如果文件存在
mode = int(input("按ID查输入1,按姓名查输入2:"))
if mode == 1:
id = input("请输入要查找的ID:")
elif mode == 2:
name = input("请输入要查找的名字:")
else:
print("您输入的有误,请重新输入!")
search()
with open(filename, 'r', encoding='UTF8') as file: # 读取保存文件里面的内容
student = file.readlines() # 按行读取
for list in student: # 实际上student是sava(student)函数的变量,与insert函数保存的stdentList列表一样
d = dict(eval(list)) # 将结果转成字典,eval作用:打印里面的结果;例:eval('3+2-9'),→-4
if id is not None: # 如果输入的是ID
if d['id'] == id: # 如果输入的ID与文件中的字典键值对应
student_query.append(d) # 将查询到的结果保存在该列表内
elif name is not None: # 如果输入的是名字
if d['name'] == name:
student_query.append(d)
show_student(student_query) # 显示查询结果
student_query.clear() # 清理查询结果
inputMark = input("是否继续查询? (y/n):") # 是否继续查询
if inputMark == "y":
mark = True
else:
mark = False
else:
print("暂未保存数据!\n")
return
提示:查询函数的调用主要在于是否添加过学生信息,如果之前没有添加过学生信息,就不会展现查询结果
3.删除函数delete()
当需要对某个学生信息进行删除时就要用到delete()函数,此函数主要操作我们建立的存储学生信息的文本文件(后面会给出)
def delete():
mark = True
while mark:
studentId = input("请输入要删除的学生ID:") # 用户输入要删除的学生ID
if studentId is not None: # 如果输入的ID存在
if os.path.exists(filename): # 判断目标文件是否存在
with open(filename, 'r', encoding='UTF8') as rfile: # 如果文件存在,打开文件
student_old = rfile.readlines() # 每行读取存在的文件
else:
student_old = [] # 如果目标文件不在,则为空
ifdel = False # 标记是否删除
if student_old: # 如果文件里面不为空
with open(filename, 'w', encoding='UTF8') as wfile: # 以写的方式打开文件
d = {} # 定义空字典
for list in student_old: # 每行读取查询到的信息
d = dict(eval(list))
if d['id'] != studentId: # 如果ID不等于学生ID
wfile.write(str(d) + "\n") # 将一条学生信息写入文件
else:
ifdel = True # 标记已经删除
if ifdel:
print("ID为%s的学生信息已经被删除。。。" % studentId)
else:
print("没有找到ID为%s的学生信息。。。" % studentId)
else:
print("无该生信息...")
break
show()
inputMark = input("是否继续删除?(y/n):")
if inputMark == 'y':
mark = True
else:
mark = False
4.修改函数modify()
此函数主要用于修改信息,当某个学生的信息录入与实际不符合,就可以调用这个函数对数据进行修改
def modify():
show()
if os.path.exists(filename):
with open(filename, 'r', encoding='UTF8') as rfile:
student_old = rfile.readlines()
else:
return
studentid = input("请输入要修改学生的ID:")
with open(filename, 'w', encoding='UTF8') as wfile:
for student in student_old:
d = dict(eval(student))
if d["id"] == studentid:
print("找到这名学生,可以修改他的信息!")
while True:
try:
d["name"] = input("请输入姓名:")
d["chinese"] = input("请输入语文成绩:")
d["maths"] = input("请输入数学成绩:")
d["english"] = input("请输入英语成绩")
except:
print("您输入的有误,请重新输入!")
else:
break
student = str(d)
wfile.write(student + "\n")
print("修改成功!")
else:
wfile.write(student)
mark = input("是否继续修改其他学生信息? (y/n):")
if mark == "y":
modify()
5.排序函数sort()
排序的方式有按某一科成绩或者总成绩进行排序
def sort():
global ascORdescBool
show()
if os.path.exists(filename):
with open(filename, 'r', encoding='UTF8') as file:
student_old = file.readlines()
student_new = []
for list in student_old:
d = dict(eval(list))
student_new.append(d)
else:
return
ascORdesc = input("请选择(0升序、1降序):")
if ascORdesc == "0":
ascORdescBool = False
elif ascORdesc == "1":
ascORdescBool = True
else:
print("您输入有误,请重新输入!")
sort()
mode = input("请选择排序方式(1按英语成绩排序、2按数学成绩排序、3按语文成绩排序、0按总成绩排序):")
if mode == "1":
student_new.sort(key=lambda x: x["englishi"], reverse=ascORdescBool)
elif mode == "2":
student_new.sort(key=lambda x: x["maths"], reverse=ascORdescBool)
elif mode == "3":
student_new.sort(key=lambda x: x["chinese"], reverse=ascORdescBool)
elif mode == "0":
student_new.sort(key=lambda x: x["maths"] + x["english"] + x["chinese"], reverse=ascORdescBool)
else:
print("您输入的有误,请重新输入!")
sort()
show_student(student_new)
6.统计函数total()、显示函数show()
录入所有学生信息后,现在想查看所有学生信息,就要用到show()函数,统计一共录入多少学生用到total()函数
# 显示所有学生信息
def show():
student_new = []
if os.path.exists(filename):
with open(filename, 'r', encoding='UTF8') as rfile:
student_old = rfile.readlines()
for list in student_old:
student_new.append(eval(list))
if student_new:
show_student(student_new)
else:
print("暂未保存数据信息。。。")
def show_student(studentList):
if not studentList:
print("(o@.@o) 无数据信息 (o@.@o) \n")
return
format_title = "{:^6}{:^12}\t{:^8}\t{:^10}\t{:^10}\t{:^10}"
print(format_title.format("ID", "名字", "英语成绩", "数学成绩", "语文成绩", "总成绩"))
format_data = "{:^6}{:^12}\t{:^12}\t{:^12}\t{:^12}\t{:^12}"
for info in studentList:
print(format_data.format(info.get("id"), info.get("name"), str(info.get("english")), str(info.get("maths")),
str(info.get("chinese")),
str(info.get("english") + info.get("maths") + info.get("chinese")).center(12)))
# 统计学生总人数
def total():
if os.path.exists(filename):
with open(filename, 'r', encoding='UTF8') as rfile:
student_old = rfile.readlines()
if student_old:
print("一共有 %d 名学生!" % len(student_old))
else:
print("还没有录入学生信息!")
else:
print("暂未保存数据信息。。。")
三、主函数介绍
上面我们介绍了主要的功能函数,如何将上面函数整合起来,下面我们通过主函数来建立他们之间的关联关系
def main():
ctrl = True # 定义循环
print("*****欢迎登陆学生信息管理系统*****")
login = input("请输入您的账号:")
password = input("请输入您的密码:")
while ctrl:
if login.strip() == account['login'].strip() and password.strip() == account['password'].strip():
menu() # 显示页面菜单
option = input("请选择:") # 选择菜单项
open_str = int(re.sub("\D", "", option)) # 提取数字(在输入的值中用空格替换所有字母符号,保留数字【"\D"】,d:去掉数字)
if open_str == 0: # 退出选择界面
print("您已经退出学生信息管理系统!")
ctrl = False # 循环结束
elif open_str == 1: # 录入学生成绩信息
insert()
elif open_str == 2: # 查询学生成绩信息
search()
elif open_str == 3: # 删除学生成绩信息
delete()
elif open_str == 4: # 修改学生成绩信息
modify()
elif open_str == 5: # 对学生成绩排序
sort()
elif open_str == 6: # 统计学生总人数
total()
elif open_str == 7: # 显示所有学生信息
show()
else:
print("您输入的账号或密码错误!!!")
break
四、程序用户可视化功能界面
上面主要功能函数我们无法同时使用所有功能,因此我们创建一个可供用于选择的可视化界面。用户只需输入数字就可调用对应的功能函数
def menu():
# 输出菜单
print("""
▛—————————————————————学生信息管理系统———————————————————————▜
| |
| |
| ===============功能菜单================== |
| |
| |
| 1 录入学生信息 |
| 2 查找学生信息 |
| 3 删除学生信息 |
| 4 修改学生信息 |
| 5 排序 |
| 6 统计学生总人数 |
| 7 显示所有学生信息 |
| 0 退出系统 |
| |
| ========================================== |
| 说明:通过数字或⬆⬇方向键选择菜单 |
▙___________________________________________________________▟
""")
五、完整代码
import os
import re
filename = "students.txt"
account = {}
account['login'] = str(input("请创建您的账号:"))
account['password'] = str(input("请输入您的密码:"))
print("注册成功,您的账号是:", account['login'].strip())
def main():
ctrl = True # 定义循环
print("*****欢迎登陆学生信息管理系统*****")
login = input("请输入您的账号:")
password = input("请输入您的密码:")
while ctrl:
if login.strip() == account['login'].strip() and password.strip() == account['password'].strip():
menu() # 显示页面菜单
option = input("请选择:") # 选择菜单项
open_str = int(re.sub("\D", "", option)) # 提取数字(在输入的值中用空格替换所有字母符号,保留数字【"\D"】,d:去掉数字)
if open_str == 0: # 退出选择界面
print("您已经退出学生信息管理系统!")
ctrl = False # 循环结束
elif open_str == 1: # 录入学生成绩信息
insert()
elif open_str == 2: # 查询学生成绩信息
search()
elif open_str == 3: # 删除学生成绩信息
delete()
elif open_str == 4: # 修改学生成绩信息
modify()
elif open_str == 5: # 对学生成绩排序
sort()
elif open_str == 6: # 统计学生总人数
total()
elif open_str == 7: # 显示所有学生信息
show()
else:
print("您输入的账号或密码错误!!!")
break
def menu():
# 输出菜单
print("""
▛—————————————————————学生信息管理系统———————————————————————▜
| |
| |
| ===============功能菜单================== |
| |
| |
| 1 录入学生信息 |
| 2 查找学生信息 |
| 3 删除学生信息 |
| 4 修改学生信息 |
| 5 排序 |
| 6 统计学生总人数 |
| 7 显示所有学生信息 |
| 0 退出系统 |
| |
| ========================================= |
| 说明:通过数字或⬆⬇方向键选择菜单 |
▙__________________________________________________________▟
""")
def save(student): # 建立保存学生信息函数
try:
students_txt = open(filename, 'a', encoding='UTF8') # 追加模式打开学生信息文本文件
except Exception as e:
students_txt = open(filename, 'w', encoding='UTF8') # 如果文件不存在,则写入内容
for info in student:
students_txt.write(str(info) + "\n") # 将添加的学生信息写入到student_txt文件中
students_txt.close()
def insert():
stdentList = [] # 建立学生信息表为空列表
mark = True
while mark:
id = input("请输入ID(如242560):").strip() # 用户输入学生ID
if not id: # 如果id为空或者不合格,退出循环
break
name = input("请输入名字:").strip() # 输入名字
if not name: # 如果没有名字,循环结束
break
try:
chinese = int(input("请输入语文成绩:")) # 输入语文成绩
maths = int(input("请输入数学成绩:")) # 输入数学成绩
english = int(input("请输入英语成绩")) # 输入英语成绩
except:
print("输入无效,不是整数型。。。。。。重新输入!") # 如果输入无效,去掉输入的信息
continue
# 将学生信息保存到字典
stdent = {'id': id, 'name': name, 'chinese': chinese, 'maths': maths, 'english': english}
stdentList.append(stdent) #将学生成绩以字典的形式添加到stdentList空列表中
inputMark = input("是否继续添加? (y/n):")
if inputMark == "y":
mark = True
else:
mark = False
save(stdentList)
print("学生信息录入完毕!!!")
def search():
mark = True
student_query = []
while mark:
id = "" # 定义ID为空
name = "" # 定义名字为空
if os.path.exists(filename): # 如果文件存在
mode = int(input("按ID查输入1,按姓名查输入2:"))
if mode == 1:
id = input("请输入要查找的ID:")
elif mode == 2:
name = input("请输入要查找的名字:")
else:
print("您输入的有误,请重新输入!")
search()
with open(filename, 'r', encoding='UTF8') as file: # 读取保存文件里面的内容
student = file.readlines() # 按行读取
for list in student: # 实际上student是sava(student)函数的变量,与insert函数保存的stdentList列表一样
d = dict(eval(list)) # 将结果转成字典,eval作用:打印里面的结果;例:eval('3+2-9'),→-4
if id is not None: # 如果输入的是ID
if d['id'] == id: # 如果输入的ID与文件中的字典键值对应
student_query.append(d) # 将查询到的结果保存在该列表内
elif name is not None: # 如果输入的是名字
if d['name'] == name:
student_query.append(d)
show_student(student_query) # 显示查询结果
student_query.clear() # 清理查询结果
inputMark = input("是否继续查询? (y/n):") # 是否继续查询
if inputMark == "y":
mark = True
else:
mark = False
else:
print("暂未保存数据!\n")
return
def delete():
mark = True
while mark:
studentId = input("请输入要删除的学生ID:") # 用户输入要删除的学生ID
if studentId is not None: # 如果输入的ID存在
if os.path.exists(filename): # 判断目标文件是否存在
with open(filename, 'r', encoding='UTF8') as rfile: # 如果文件存在,打开文件
student_old = rfile.readlines() # 每行读取存在的文件
else:
student_old = [] # 如果目标文件不在,则为空
ifdel = False # 标记是否删除
if student_old: # 如果文件里面不为空
with open(filename, 'w', encoding='UTF8') as wfile: # 以写的方式打开文件
d = {} # 定义空字典
for list in student_old: # 每行读取查询到的信息
d = dict(eval(list))
if d['id'] != studentId: # 如果ID不等于学生ID
wfile.write(str(d) + "\n") # 将一条学生信息写入文件
else:
ifdel = True # 标记已经删除
if ifdel:
print("ID为 %s 的学生信息已经被删除。。。" % studentId)
else:
print("没有找到ID为 %s 的学生信息。。。" % studentId)
else:
print("无学生信息...")
break
show()
inputMark = input("是否继续删除? (y/n) :")
if inputMark == 'y':
mark = True
else:
mark = False
def modify():
show()
if os.path.exists(filename):
with open(filename, 'r', encoding='UTF8') as rfile:
student_old = rfile.readlines()
else:
return
studentid = input("请输入要修改学生的ID:")
with open(filename, 'w', encoding='UTF8') as wfile:
for student in student_old:
d = dict(eval(student))
if d["id"] == studentid:
print("找到这名学生,可以修改他的信息!")
while True:
try:
d["name"] = input("请输入姓名:")
d["chinese"] = input("请输入语文成绩:")
d["maths"] = input("请输入数学成绩:")
d["english"] = input("请输入英语成绩")
except:
print("您输入的有误,请重新输入!")
else:
break
student = str(d)
wfile.write(student + "\n")
print("修改成功!")
else:
wfile.write(student)
mark = input("是否继续修改其他学生信息? (y/n):")
if mark == "y":
modify()
def sort():
global ascORdescBool
show()
if os.path.exists(filename):
with open(filename, 'r', encoding='UTF8') as file:
student_old = file.readlines()
student_new = []
for list in student_old:
d = dict(eval(list))
student_new.append(d)
else:
return
ascORdesc = input("请选择(0升序、1降序):")
if ascORdesc == "0":
ascORdescBool = False
elif ascORdesc == "1":
ascORdescBool = True
else:
print("您输入有误,请重新输入!")
sort()
mode = input("请选择排序方式(1按英语成绩排序、2按数学成绩排序、3按语文成绩排序、0按总成绩排序):")
if mode == "1":
student_new.sort(key=lambda x: x["englishi"], reverse=ascORdescBool)
elif mode == "2":
student_new.sort(key=lambda x: x["maths"], reverse=ascORdescBool)
elif mode == "3":
student_new.sort(key=lambda x: x["chinese"], reverse=ascORdescBool)
elif mode == "0":
student_new.sort(key=lambda x: x["maths"] + x["english"] + x["chinese"], reverse=ascORdescBool)
else:
print("您输入的有误,请重新输入!")
sort()
show_student(student_new)
def total():
if os.path.exists(filename):
with open(filename, 'r', encoding='UTF8') as rfile:
student_old = rfile.readlines()
if student_old:
print("一共有 %d 名学生!" % len(student_old))
else:
print("还没有录入学生信息!")
else:
print("暂未保存数据信息。。。")
def show():
student_new = []
if os.path.exists(filename):
with open(filename, 'r', encoding='UTF8') as rfile:
student_old = rfile.readlines()
for list in student_old:
student_new.append(eval(list))
if student_new:
show_student(student_new)
else:
print("暂未保存数据信息。。。")
def show_student(studentList):
if not studentList:
print("(o@.@o) 无数据信息 (o@.@o) \n")
return
format_title = "{:^6}{:^12}\t{:^8}\t{:^10}\t{:^10}\t{:^10}"
print(format_title.format("ID", "名字", "英语成绩", "数学成绩", "语文成绩", "总成绩"))
format_data = "{:^6}{:^12}\t{:^12}\t{:^12}\t{:^12}\t{:^12}"
for info in studentList:
print(format_data.format(info.get("id"), info.get("name"), str(info.get("english")), str(info.get("maths")),
str(info.get("chinese")),
str(info.get("english") + info.get("maths") + info.get("chinese")).center(12)))
if __name__ == "__main__":
main()
六、运行效果
总结
项目代码核心主要在于对文件、列表、字典的操作,文件操作用于对插入的数据进行保存,用于查询、删除数据,列表的功能在主要用于,存储单个学生信息,字典主要是起到对数据进行归类存储。总体来讲各个功能实现不是很难,难点在于对学生的成绩(单科或总成绩)进行排序,这个功能实现比较复杂需要大家熟练掌握相关知识点。