Python学生管理系统

        随着高校的扩招,需要处理的学生信息日趋加大,不仅花费大量的教师资源,处理的
效率还十分低下。为提高学生管理的管理水平,优化资源,尽可能降低管理成本成为学生
管理的新课题,学生管理系统是从学生管理现状出发,根据学生管理的新要求进行开发设
计的,它解决了学生管理数据信息量大,修改不方便,对一系列数据进行分析时花费时间
长等问题,帮助学生管理人员有效管理学生信息,成为管理高校中必不可少的管理工具。

        学生管理系统具备的功能:

                1. 添加学生及成绩信息

                2.将学生信息保存到文件中

                3.修改和删除学生信息

                4.查询学生信息

                5.根据学生成绩进行排序

                6.统计学生的总分

        实现主函数:

编号 功能
0 退出系统
1 录入学生信息,调用insert()函数
2 查找学生信息,调用search()函数
3 删除学生信息,调用delete()函数
4 修改学生信息,调用modify()函数
5 对学生成绩排序,调用sort()函数
6 统计学生总人数,调用total()函数
7

显示所有的学生信息,调用show()函数

一、录入学生信息

def insert():
    student_list = []
    while True:
        id = input("请输入学生id(如1001):")
        if not id:  #判读空字符串;空字符串ASCII码值为False;
            break;
        name = input("请输入学生姓名:")
        if not name:
            break
        try:
            englist = int(input("请输入英语成绩:"))
            python = int(input("请输入python成绩:"))
            java = int(input("请输入Java成绩:"))
        except:
            print("成绩输入错误,请重新输入!")
            continue
        #录入学生信息
        student = {'id':id,'name':name,'englist':englist,'python':python,'java':java}
        student_list.append(student)
        answer = input("是否继续添加学生信息Y/N\n")
        if answer == 'Y' or answer == 'y':
            continue
        else:
            print("学生信息录入完毕!")
            break
    save(student_list)
def save(lit):
    try:
        stu_txt = open(filename,'a',encoding="UTF-8")
    except:
        stu_txt = open(filename, 'w', encoding="UTF-8")
    for item in lit:
        stu_txt.write(str(item)+"\n")
    stu_txt.close()

二、表头与主函数

def menum():
    print("===================学生信息管理系统=====================")
    print("---------------------功能菜单-------------------")
    print("                 1.录入学生信息")
    print("                 2.查找学生信息")
    print("                 3.删除学生信息")
    print("                 4.修改学生信息")
    print("                 5.排序")
    print("                 6.统计学生总人数")
    print("                 7.显示所有学生信息")
    print("                 0.退出系统")
    print("----------------------------------------------")
def main():
    while True:
        menum()
        choice = int(input("请选择:"))
        if choice in [0,1,2,3,4,5,6,7]:
            if choice == 0:
                src = input("确定要退出系统吗:Y/N")
                if src == 'Y' or src == '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 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")#id相同的将不会写入;
                        else:
                            flag = True
                    if flag :
                        print(f'id为{student_id}的学生信息已删除')
                    else:
                        print(f'没有找到id为{student_id}的学生信息!!')
        else:
            print("没有学生信息!")
            break;
        show()
        answer = input("是否继续删除!")
        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:")
    if student_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['englist'] = input("请输入England成绩:")
                            d['python'] = input("请输入python成绩:")
                            d['java'] = input("请输入java成绩:")
                        except:
                            print("信息输入错误,请重新输入!!")
                        else:
                            break
                    wfile.write(str(d)+"\n")
                    print('修改成功~')
                else:
                    wfile.write(str(d)+"\n")
                    print('未找到修改学生的ID~~')
            answer = input("是否继续修改:")
            if answer == 'y' or answer == 'Y':
                modify()
    else:
        print('输入学生ID错误!')

五、查找学生信息

def search():
    stuent_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:
                stuent = rfile.readlines()
                for item in stuent:
                    d = dict(eval(item))
                    if id != '':
                        if d['id'] == id:
                            stuent_query.append(d)
                    elif name != '':
                        if d['name'] == name:
                            stuent_query.append(d)
                        pass
            show_student(stuent_query)
            stuent_query.clear()
            answer = input("是否继续查询学生:")
            if answer == 'y' or answer == 'Y':
                continue
            else:
                break
        else:
            print("暂未保存学生信息!!")
            return

学生信息输出格式化 函数

def show_student(lst):
    if len(lst) == 0:
        print("没有查到学生信息,数据无法显示!!")
        return
    #标题结构定义
    format_tirle = '{:^6}\t{:^12}\t{:^8}\t{:^10}\t{:^10}\t{:^8}'
    print(format_tirle.format('ID','姓名','英语成绩','python成绩','java成绩','总成绩'))
    #显示内容格式
    format_data = '{:^6}\t{:^12}\t{:^8}\t{:^10}\t{:^10}\t{:^8}'
    for item in lst:
        print(format_data.format(item.get('id'),
                                 item.get('name'),
                                item.get('englist'),
                                 item.get('python'),
                                 item.get('java'),
                                 int(item.get('englist'))+int(item.get('python'))+int(item.get('java'))))

六、学生成绩排序

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:
                d = dict(eval(item))
                student_new.append(d)
    else:
        print("暂无数据,无法输出!!")
    aesc_or = input('请选择排序方式(0:升序;1:降序)')
    if aesc_or == '0':
        aesc_or_bool = False
    elif aesc_or == '1':
        aesc_or_bool = True
    else:
        print("输入有误,请重新输入!!!")
        sort()
    mode = input('请选择排序方式(1.按英语排序 2.按python排序 3.按Java排序 0.按总成绩排序)')
    if mode == '1':
        student_new.sort(key= lambda x:int(x['englist']),reverse=aesc_or_bool)#lambda匿名函数;x代表字典每一项
    elif mode == '2':
        student_new.sort(key= lambda x:int(x['python']),reverse=aesc_or_bool)
    elif mode == '3':
        student_new.sort(key= lambda x:int(x['java']),reverse=aesc_or_bool)
    elif mode == '0':
        student_new.sort(key= lambda x:int(x['englist'])+int(x['java'])+int(x['python']),reverse=aesc_or_bool)
    else:
        print('输入错误!请重新输入!!')
        sort()
    show_student(student_new)

七、统计学生总人数

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('没有录入学生信息,数据无法输出!!')

八、显示所有学生

 student_list = []
    if os.path.exists(filename):
        with open(filename,'r',encoding='UTF-8') as rfile:
            student = rfile.readlines()
            for item in student:
                student_list.append(eval(item))
            if student_list:
                show_student(student_list)
            else:
                print("数据库中没有学生信息!!")
    else:
        print('暂时没有学生信息!!')

九、制作学生管理系统可执行文件

        1.利用cmd命令导入:pip install PyInstaller模块安装

Python学生管理系统_第1张图片

         2.开始导入

Python学生管理系统_第2张图片

Python学生管理系统_第3张图片

         【注】红线标注的就是导出可执行文件的地址

十、原文件

student.txt

stusystem.py

stusystem.exe

【注】可执行文件导入成功后,执行时,需要将student.txt与stusystem.exe文件放到同一个文件夹中;(原文件可以直接下载)

                        加油!还有什么好的想法可以私信;

                                        ——^0^

你可能感兴趣的:(python,开发语言)