学籍管理系统(不要求界面)
要求
要求:
1.学生的信息用结构体来表示。学生的信息(学号id、学生姓名sname、性别xb、年龄age、学生籍贯jg、班级bj,成绩score)采用类设计。
2.能够录入学生信息,能够显示所有学生信息。
3.能够按学号、姓名查询并显示单个学生的信息,能够按性别、籍贯、班级进行类别查询并显示,查询方式可以自己补充。
4.能够按类统计每个班级或性别等的平均成绩。
5.能够按成绩进行排序,并输出排序结果,能够查询某班成绩前10名的学生。
6.能够添加、删除、修改学生的信息。
7.系统的各个功能模块要求用函数实现。
8.用数组或链表来表示(建议用结构体数组)。
9.学生的信息保存在数据库中里。
提示:
编写主菜单函数,返回相应的功能选项数字,主函数根据此数字调用相应的功能函数。编写各功能模块函数。最后进行综合调试。
实现(jupyter notebook)
import numpy as np
import pandas as pd
#定义Student类
class Student():
def __init__(self,bj=0,id=0,sname="name",xb=" ",age=0,jg=" ",score=0):
self.bj=bj
self.id=id
self.sname=sname
self.xb=xb
self.age=age
self.jg=jg
self.score=score
#定义home类,并设计函数实现各个功能模块
class home:
#构造函数
def __init__(self,lt):
self.lt=lt#lt为存储的学生信息
#显示所有学生信息的函数
def display(self):
for i in range(len(self.lt)):
print("班级 : {}, 学号 : {}, 姓名 : {}, 性别 : {}, 年龄 : {}, 学生籍贯 : {}, 成绩 : {}".format(self.lt[i].bj,self.lt[i].id,self.lt[i].sname,self.lt[i].xb,self.lt[i].age,self.lt[i].jg,self.lt[i].score))
print("显示",len(self.lt),"个学生信息成功")
#按学号、姓名查询并显示单个学生的信息,能够按性别、籍贯、班级进行类别查询并显示的函数
def inquire_information(self):
print("请输入序号选择查询单个学生信息或是某一类别学生信息:")
print("1.查询单个学生信息 2.查询某一类别学生信息")
choice2=input("请选择操作: ")
if choice2=="1": #查询单个学生信息
print("请输入序号选择按学号或是姓名查询学生信息:")
print("1.学号 2.姓名")
choice3=input("请选择: ")
if choice3=="1": #按学号查询
xuehao=input("请输入学号: ")
j=0#判断是否匹配到学生的因素
for i in range(len(self.lt)): #序号
if xuehao==str(self.lt[i].id): #输入的学号与学生的学号匹配
print("班级 : {}, 学号 : {}, 姓名 : {}, 性别 : {}, 年龄 : {}, 学生籍贯 : {}, 成绩 : {}".format(self.lt[i].bj,self.lt[i].id,self.lt[i].sname,self.lt[i].xb,self.lt[i].age,self.lt[i].jg,self.lt[i].score))
print("查询成功")
j=1
break #查询到学生信息则退出
if j==0:
print("未查询到学生信息,请检查学号")
elif choice3=="2": #按姓名查询
xingming=input("请输入姓名: ")
j=0#判断是否匹配到学生的因素
for i in range(len(self.lt)): #序号
if xingming==self.lt[i].sname: #输入的姓名与学生的姓名匹配
print("班级 : {}, 学号 : {}, 姓名 : {}, 性别 : {}, 年龄 : {}, 学生籍贯 : {}, 成绩 : {}".format(self.lt[i].bj,self.lt[i].id,self.lt[i].sname,self.lt[i].xb,self.lt[i].age,self.lt[i].jg,self.lt[i].score))
print("查询成功")
j=1
break #查询到学生信息则退出
if j==0:
print("未查询到学生信息,请检查姓名")
else:#若不是输入1或2则提示出错
print("错误!!!请输入 1 或 2 选择按学号或姓名查询其学生信息")
elif choice2=="2":#查询某一类别学生信息
print("1.性别 2.籍贯 3.班级")
choice4=input("请选择: ")
if choice4=="1": #按性别查询
xingbie=input("请输入性别: ")
j=0#判断是否匹配到学生的因素
for i in range(len(self.lt)):
if xingbie==self.lt[i].xb: #输入的姓名与学生姓名匹配
print("班级 : {}, 学号 : {}, 姓名 : {}, 性别 : {}, 年龄 : {}, 学生籍贯 : {}, 成绩 : {}".format(self.lt[i].bj,self.lt[i].id,self.lt[i].sname,self.lt[i].xb,self.lt[i].age,self.lt[i].jg,self.lt[i].score))
print()
j=1
if j==1:
print("查询成功")
else:
print("查询失败,请检查性别")
elif choice4=="2": #按籍贯查询
jiguan=input("请输入籍贯: ")
j=0#判断是否匹配到学生的因素
for i in range(len(self.lt)):
if jiguan==self.lt[i].jg: #输入的籍贯与学生籍贯匹配
print("班级 : {}, 学号 : {}, 姓名 : {}, 性别 : {}, 年龄 : {}, 学生籍贯 : {}, 成绩 : {}".format(self.lt[i].bj,self.lt[i].id,self.lt[i].sname,self.lt[i].xb,self.lt[i].age,self.lt[i].jg,self.lt[i].score))
print()
j=1
#判断是否遍历所有学生
if j==1:
print("查询成功")
else:
print("查询失败,请检查籍贯")
elif choice4=="3": #按班级查询
banji=input("请输入班级: ")
j=0#判断是否匹配到学生的因素
for i in range(len(self.lt)):
if int(banji)==self.lt[i].bj: #输入的班级与学生班级匹配
print("班级 : {}, 学号 : {}, 姓名 : {}, 性别 : {}, 年龄 : {}, 学生籍贯 : {}, 成绩 : {}".format(self.lt[i].bj,self.lt[i].id,self.lt[i].sname,self.lt[i].xb,self.lt[i].age,self.lt[i].jg,self.lt[i].score))
print()
j=1
#判断是否遍历所有学生
if j==1:
print("查询成功")
else:
print("查询失败,请检查班级号")
else:#若不是输入1或2或3则提示出错
print("错误!!!请输入 1 或 2 或 3 选择按性别或籍贯或班级查询这一类别学生信息")
else:#若不是输入1或2查询则提示出错
print("错误!!!请输入 1 或 2 选择查询单个学生信息或某一类别学生信息")
#统计平均成绩的函数
def inquire_ave_score(self):
print("请选择按班级或是性别统计平均成绩")
print("1.班级 2.性别")
choice5=input("请选择: ")
if choice5=="1":#按班级统计
choice6=input("请输入班级号: ")
all_score=0#学生的总成绩
j=0
for i in range(len(self.lt)):#序号
if choice6==str(self.lt[i].bj):#输入的班级号与学生班级号匹配
all_score+=self.lt[i].score#符合匹配的学生成绩相加
j=1
#判断是否遍历所有学生
if j==1:
print(choice6,"班级的平均成绩为",'{:.3f}'.format(all_score/(i+1)))#输出平均成绩
print("统计成功")
else:
print("统计失败,请检查班级号")
elif choice5=="2":#按性别统计
choice7=input("请输入性别: ")
all_score=0#学生的总成绩
j=0#判断是否匹配到学生的因素
for i in range(len(self.lt)):
if choice7==self.lt[i].xb:#输入的性别与学生性别匹配
all_score+=self.lt[i].score#符合匹配的学生成绩相加
j=1
#判断是否遍历所有学生
if j==1:
print("性别为",choice7,"的平均成绩为",'{:.3f}'.format(all_score/(i+1)))#输出平均成绩
print("统计成功")
else:
print("统计失败,请检查性别")
else:#如果不是选择班级或性别统计则提示出错
print("请输入 1 或2 选择按班级或性别统计这一类别学生平均成绩")
#冒泡排序函数
def sort_by_score(self):
for i in range(len(self.lt) - 1):
for j in range(len(self.lt) - 1 - i):
if self.lt[j].score < self.lt[j + 1].score:
t = self.lt[j]
self.lt[j] = self.lt[j + 1]
self.lt[j + 1] = t
test.display()#排序后输出
print("排序成功")
qian10=input("请选择是否查询成绩前10名学生信息: y/n\n")
if qian10=="y":#输出某一班级前10名学生
choose_class=input("请输入班级号以查询: ")
n=0#只输出前面10个学生学生信息
for i in range(len(self.lt)):
if choose_class==str(self.lt[i].bj):
print("班级:{},学号:{},姓名:{},性别:{},年龄:{},学生籍贯:{},成绩:{}".format(self.lt[i].bj,
self.lt[i].id,
self.lt[i].sname,
self.lt[i].xb,
self.lt[i].age,
self.lt[i].jg,
self.lt[i].score,))
print()
n+=1#累加10名
if n==10:
break
if n!=0:
print("显示",choose_class,"班级前10名学生成绩成功")
else:
print("错误!!!请正确输入班级号")
elif qian10=="n":#不输出
pass
else:
print("错误!!!请输入 y 或 n 选择是否输出一个班级前10名学生信息")
#添加、删除、修改学生信息的操作
def operation_to_information(self):
print("请选择操作")
print("1.添加 2.删除 3.修改")
choice8=input("请选择: ")
if choice8=="1":#添加学生信息
j=1
while j:
inn1=input("请输入学生班级号: ")#判断是否是数字
for i in inn1:
if i in '1234567890':
j=0
else:
j=1
print("输出错误")
break
inn1=int(inn1)
j=1
while j:
inn2=input("请输入学生学号: ")
for i in inn2:
if i in '1234567890':
j=0
else:
j=1
print("输出错误")
break
inn2=int(inn2)
inn3=input("请输入学生姓名: ")
inn4=input("请输入学生性别: ")
j=1
while j:
inn5=input("请输入学生年龄: ")
for i in inn5:
if i in '1234567890':
j=0
else:
j=1
print("输出错误")
break
inn5=int(inn5)
inn6=input("请输入学生籍贯: ")
j=1
while j:
inn7=input("请输入学生成绩: ")
for i in inn7:
if i in '1234567890.':
j=0
else:
j=1
print("输出错误")
break
inn7=float(inn7)
newone=Student(inn1,inn2,inn3,inn4,inn5,inn6,inn7)#新的学生的信息
self.lt.append(newone)#添加
print("添加成功")
elif choice8=="2":#删除学生信息
student_id=input("请输入需要删除的学生的学号: ")#根据学号选择学生删除信息
j=0#判断是否查询到学生
for i in range(len(self.lt)):
if student_id==str(self.lt[i].id):#输入的学号与学生学号匹配
self.lt.remove(self.lt[i])
print("删除成功")
j=1
break
#判断是否遍历所有学生
if j==0:
print("未查询到学生信息,请检查学号")
elif choice8=="3":#修改学生信息
print("请输入学号选择要修改信息的学生")
id2=input("请输入学号: ")#根据学号选择学生修改信息
for i in range(len(self.lt)):
if id2==str(self.lt[i].id):#输入的学号与学生学号匹配
print("请选择要修改哪一项信息")
y=1#循环条件
while y:#可循环,选择修改该学生信息
print("1.班级 2.学号 3.姓名 4.性别 5.年龄 6.籍贯 7.成绩")
change10=input("请选择: ")
if change10=="1":
k=1
while k:
change2=input("请输入新的班级号: ")
for j in change2:
if j in '1234567890':
k=0
else:
k=1
print("输入错误")
break
self.lt[i].bj=int(change2)#修改信息
#修改后输出该学生信息
print("修改后的学生信息如下: \n","班级:{},学号:{},姓名:{},性别:{},年龄:{},学生籍贯:{},成绩:{}".format(self.lt[i].bj,self.lt[i].id,self.lt[i].sname,self.lt[i].xb,self.lt[i].age,self.lt[i].jg,self.lt[i].score))
elif change10=="2":
k=1
while k:
change2=input("请输入新的学号: ")
for j in change2:
if j in '1234567890':
k=0
else:
k=1
print("输入错误")
break
self.lt[i].id=int(change2)#修改信息
print("修改后的学生信息如下: \n","班级:{},学号:{},姓名:{},性别:{},年龄:{},学生籍贯:{},成绩:{}".format(self.lt[i].bj,self.lt[i].id,self.lt[i].sname,self.lt[i].xb,self.lt[i].age,self.lt[i].jg,self.lt[i].score))
elif change10=="3":
change2=input("请输入新的姓名: ")
self.lt[i].sname=change2
print("修改后的学生信息如下: \n","班级:{},学号:{},姓名:{},性别:{},年龄:{},学生籍贯:{},成绩:{}".format(self.lt[i].bj,self.lt[i].id,self.lt[i].sname,self.lt[i].xb,self.lt[i].age,self.lt[i].jg,self.lt[i].score))
elif change10=="4":
change2=input("请输入新的性别: ")
self.lt[i].xb=change2
print("修改后的学生信息如下: \n","班级:{},学号:{},姓名:{},性别:{},年龄:{},学生籍贯:{},成绩:{}".format(self.lt[i].bj,self.lt[i].id,self.lt[i].sname,self.lt[i].xb,self.lt[i].age,self.lt[i].jg,self.lt[i].score))
elif change10=="5":
k=1
while k:
change2=input("请输入新的年龄: ")
for j in change2:
if j in '1234567890':
k=0
else:
k=1
print("输入错误")
break
self.lt[i].age=int(change2)#修改信息
print("修改后的学生信息如下: \n","班级:{},学号:{},姓名:{},性别:{},年龄:{},学生籍贯:{},成绩:{}".format(self.lt[i].bj,self.lt[i].id,self.lt[i].sname,self.lt[i].xb,self.lt[i].age,self.lt[i].jg,self.lt[i].score))
elif change10=="6":
change2=input("请输入新的籍贯: ")
self.lt[i].jg=change2
print("修改后的学生信息如下: \n","班级:{},学号:{},姓名:{},性别:{},年龄:{},学生籍贯:{},成绩:{}".format(self.lt[i].bj,self.lt[i].id,self.lt[i].sname,self.lt[i].xb,self.lt[i].age,self.lt[i].jg,self.lt[i].score))
elif change10=="7":
k=1
while k:
change2=input("请输入新的成绩: ")
for j in change2:
if j in '1234567890.':
k=0
else:
k=1
print("输入错误")
break
self.lt[i].score=float(change2)#修改信息
print("修改后的学生信息如下: \n","班级:{},学号:{},姓名:{},性别:{},年龄:{},学生籍贯:{},成绩:{}".format(self.lt[i].bj,self.lt[i].id,self.lt[i].sname,self.lt[i].xb,self.lt[i].age,self.lt[i].jg,self.lt[i].score))
else:
print("错误!!!请输入 1 、 2 、 3 、 4 、 5 、 6 、 7 选择修改班级、学号、姓名、性别、年龄、籍贯、成绩")
change11=input("是否继续修改: y/n\n")
#选择是否继续修改该学生信息
if change11=="y":
y=1
elif change11=="n":
y=0
#判断是否遍历所有学生
if y==1:
print("未查询到学生信息,请检查学号")
else:
print("错误!!!请输入 1 、2 、3选择添加、删除、修改学生信息")
#将学生信息保存到数据库函数
def save_it(self):
#创建数组,临时存储学生信息
BJ=[]#存储班级
ID=[]#存储学号
SNAME=[]#存储姓名
XB=[]#存储性别
AGE=[]#存储年龄
JG=[]#存储籍贯
SCORE=[]#存储成绩
for i in range(len(self.lt)):#添加信息到临时存储数组中
BJ.append(self.lt[i].bj)
ID.append(self.lt[i].id)
SNAME.append(self.lt[i].sname)
XB.append(self.lt[i].xb)
AGE.append(self.lt[i].age)
JG.append(self.lt[i].jg)
SCORE.append(self.lt[i].score)
#修改数组格式为series
BJ=pd.Series(BJ)
ID=pd.Series(ID)
SNAME=pd.Series(SNAME)
XB=pd.Series(XB)
AGE=pd.Series(AGE)
JG=pd.Series(JG)
SCORE=pd.Series(SCORE)
#创建dataframe存储学生信息
result=pd.concat([BJ,ID,SNAME,XB,AGE,JG,SCORE],axis=1,keys=['bj','id','sname','xb','age','jg','score'])
result.to_csv('data.csv') #将学生信息保存到数据库
print("保存成功")
#主函数
if __name__=="__main__":
data=pd.read_csv('data.csv',encoding = 'gbk')#加载数据
# 设置打印宽度
pd.set_option('display.unicode.ambiguous_as_wide', True)
pd.set_option('display.unicode.east_asian_width', True)
pd.set_option('display.width', 200)
m=data.shape[0]#数据行数
Sentry=[]# 创建列表,以将类通过append加入其中,避免覆盖
for i in range(m):
Sentry.append(Student())
#中间量,以暂时存储从表中读取的数据
BJ=[]
ID=[]
SNAME=[]
XB=[]
AGE=[]
JG=[]
SCORE=[]
for i in range(m):
BJ.append(data.at[data.index[i],data.columns[0]])
ID.append(data.at[data.index[i],data.columns[1]])
SNAME.append(data.at[data.index[i],data.columns[2]])
XB.append(data.at[data.index[i],data.columns[3]])
AGE.append(data.at[data.index[i],data.columns[4]])
JG.append(data.at[data.index[i],data.columns[5]])
SCORE.append(data.at[data.index[i],data.columns[6]])
#将值存入类中,可以通过下标查找相关值,不会产生覆盖
for i in range(m):
Sentry[i].bj=BJ[i]
Sentry[i].id=ID[i]
Sentry[i].sname=SNAME[i]
Sentry[i].xb=XB[i]
Sentry[i].age=AGE[i]
Sentry[i].jg=JG[i]
Sentry[i].score=SCORE[i]
#定义一个home类对象
test=home(Sentry)
judge=1#用于加载管理系统
while judge:
print("-"*8,"*"*12,"-"*8)
print("-"*8,"学籍管理系统","-"*8)
print("-"*10,"序号操作","-"*10)
print("-"*9,"1.显示信息","-"*9)
print("-"*9,"2.查询信息","-"*9)
print("-"*9,"3.统计成绩","-"*9)
print("-"*9,"4.成绩排序","-"*9)
print("-"*9,"5.修改信息","-"*9)
print("-"*9,"6.保存数据","-"*9)
print("-"*9,"7.退出系统","-"*9)
choice1=int(input("请选择操作: "))
if choice1==1:
test.display()
elif choice1 == 2:
test.inquire_information()
elif choice1==3:
test.inquire_ave_score()
elif choice1==4:
test.sort_by_score()
elif choice1==5:
test.operation_to_information()
elif choice1==6:
test.save_it()
elif choice1==7:
print("退出成功")
break
else:
print("错误!!!请输入有序操作")