Python implementation of student information management system (including all codes)

Student information management system notes python

1. Demand analysis

Should have the function:

  1. Add student information and grade information
  2. Save student information in a file
  3. Modify and delete student information
  4. Query student information
  5. Sort by student grade
  6. Statistics student total score

2. System design

Seven modules of the student information management system

  1. Enter student information module

  2. Find Student Information

  3. delete student information

  4. Modify student information

  5. Student Achievement Ranking

  6. Statistics of the total number of students

  7. Show all student information

insert image description here

4. System Implementation

main()

menu()

search()

delete()

modify()

insert()

total()

show()

sort()

Five, package the project to survive the exe file

Install third-party packages

pip install PyInstaller

Open the command line and package the exe

pyinstaller -F “D:\Program Files (x86)\pycharm\PythonProject\studentsys\stusystem.py”

The location marked in red in the picture is the storage location of the exe program.

The location marked in red in the picture is the storage location of the exe program.
insert image description here

6. Code implementation

import os.path

filename = 'students.txt'


def main():
    while True:
        menu()
        choice = int(input('请选择功能'))
        if choice in [0, 1, 2, 3, 4, 5, 6, 7]:
            if choice == 0:
                answer = input('您确定退出系统吗?y/n')
                if answer == 'y' or answer == '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()
        input()


def menu():
    print('==================学生信息管理系统==============')
    print('===============功能菜单==================')
    print('\t\t\t1. 录入学生信息')
    print('\t\t\t2. 查找学生信息')
    print('\t\t\t3. 删除学生信息')
    print('\t\t\t4. 修改学生信息')
    print('\t\t\t5. 对学生成绩进行排序')
    print('\t\t\t6. 统计学生总人数')
    print('\t\t\t7. 显示所有学生信息')
    print('\t\t\t0. 退出程序')
    print('======================================')


def insert():
    student_list = []
    while True:
        id = input("请输入ID:")
        if not id:
            break
        name = input("请输入姓名:")
        if not name:
            break
        try:
            english = int(input("请输入英语成绩:"))
            python = int(input("请输入python成绩:"))
            java = int(input("请输入Java成绩:"))
        except:
            print("输入无效,请重新输入")
        # 将录入的学生信息保存在字典中
        student = {
    
    'id': id, 'name': name, 'english': english, 'python': python, 'java': java}
        # 将学生信息添加到列表中
        student_list.append(student)
        answer = input("是否继续添加y/n?")
        if answer == 'y':
            continue
        else:
            break
    # 调用save函数保存信息
    save(student_list)
    print("学生信息保存成功")


def save(lst):
    try:
        stu_txt = open(filename, 'a', encoding='utf-8')
    except:
        stu_txt = open(filename, 'w', encoding='utf-8')
    for item in lst:
        stu_txt.write(str(item) + '\n')
    stu_txt.close()


def search():
    student_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 file:
                student = file.readlines()
                for item in student:
                    d = dict(eval(item))
                    if id != '':
                        if d['id'] == id:
                            student_query.append(d)
                    elif name != '':
                        if d['name'] == name:
                            student_query.append(d)
            show_query(student_query)
            # 清空列表
            student_query.clear()
            answer = input("是否继续查询?y/n")
            if answer == 'y':
                continue
            else:
                break
        else:
            print("无学生信息")
            return


def show_query(lst):
    if len(lst) == 0:
        print("无相关信息")
        return
    # 定义标题显示格式
    format_title = '{:^6}\t{:^12}\t{:^8}\t{:^10}\t{:^10}\t{:^8}'
    print(format_title.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('english'),
                                 item.get('english'),
                                 item.get('java'),
                                 int( item.get('english')) + int( item.get('english')) + int( item.get('java'))
                                 ))


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:  # 空列表等于 False,非空列表等于True
                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')
                        else:
                            flag = True
                    if flag:
                        print(f'id为{
      
      student_id}的学生信息已被删除')
                    else:
                        print(f'没有找到学生ID为{
      
      student_id}的学生')
            else:
                print("无学生信息")
                break
            show()
            answer = input("是否继续删除?y/n")
            if answer == 'y':
                continue
            else:
                break


def modify():
    show()
    if os.path.exists(filename):
        with open(filename, 'r', encoding='utf-8') as file:
            student_old = file.readlines()
    else:
        return
    student_id = input("请输入修改学生的ID:")
    with open(filename, 'w', encoding='utf-8') as wfile:
        for item in student_old:
            d = {
    
    }
            d = dict(eval(item))
            if d['id'] == student_id:
                print("已经找到学生信息,请修改相关信息")
                while True:
                    try:
                        d['name'] = input("请输入姓名")
                        d['english'] = input("请输入英语成绩")
                        d['python'] = input("请输入python成绩")
                        d['java'] = input("请输入Java成绩")
                    except:
                        print("输入有误,请重新输入")
                    else:
                        break
                    wfile.write(str(d) + '\n')
                    print("修改成功")
            else:
                wfile.write(str(d)+'\n')
            answer = input("是否继续修改其他学生信息?y/n")
            if answer == 'y':
                modify()
            else:
                return


def sort():
    show()
    if os.path.exists(filename):
        with open(filename, 'r', encoding= 'utf-8') as file:
            students = file.readlines()
        students_new = []
        for item in students:
            d = dict(eval(item))
            students_new.append(d)
    else:
        return

    # 排序方式
    asc_or_desc = input("请选择升序 0 还是降序 1?")
    if asc_or_desc == '0':
        asc_or_desc_bool = False
    elif asc_or_desc == '1':
        asc_or_desc_bool = True
    else:
        print("输入有误,请重新输入")
        sort()
    mode = input("请选择排序方式(1.英语 2.python 3.Java 4.总成绩):")
    if mode == '1':
        students_new.sort(key=lambda x : int(x['english']), reverse=asc_or_desc_bool)
        # x 代表列表students_new中的项
    elif mode == '2':
        students_new.sort(key=lambda x: int(x['python']), reverse=asc_or_desc_bool)
    elif mode == '3':
        students_new.sort(key=lambda x: int(x['java']), reverse=asc_or_desc_bool)
    elif mode == '4':
        students_new.sort(key=lambda x: int(x['english']) + int(x['python']) + int(x['java']), reverse=asc_or_desc_bool)
    else:
        print("输入有误,请重新输入")
    show_query(students_new)


def total():
    if os.path.exists(filename):
        with open(filename, 'r', encoding='utf-8') as file:
            students = file.readlines()
            if students:
                print(f"总共有{
      
      len(students)}名学生")
            else:
                print("无学生信息")
    else:
        print("无学生信息")


def show():
    student_query = []
    if os.path.exists(filename):
        with open(filename, 'r', encoding='utf-8') as file:
            student = file.readlines()
            for item in student:
                d = dict(eval(item))
                student_query.append(d)
        show_query(student_query)
        # 清空列表
        student_query.clear()
    else:
        print("无学生信息")
        return


if __name__ == '__main__':
    main()

Guess you like

Origin blog.csdn.net/qq_43709785/article/details/127029957