用Python写的学生信息管理系统

前言

免责声明:
    本博文的初衷是分享自己学习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()

六、运行效果

总结

项目代码核心主要在于对文件、列表、字典的操作,文件操作用于对插入的数据进行保存,用于查询、删除数据,列表的功能在主要用于,存储单个学生信息,字典主要是起到对数据进行归类存储。总体来讲各个功能实现不是很难,难点在于对学生的成绩(单科或总成绩)进行排序,这个功能实现比较复杂需要大家熟练掌握相关知识点。

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

CNodeGamer

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值