学籍管理系统(不要求界面)

学籍管理系统(不要求界面)

要求

要求:
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("错误!!!请输入有序操作")
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值