一、需求分析

具备的功能

添加学生及成绩
将学生信息保存到文件中
修改和删除学生信息
查询学生信息
根据学生成绩进行排序
统计学生总分

二、系统设计

1.七大模块

录入学生信息
查找学生信息
删除学生信息
修改学生信息
学生成绩排名
统计学生总人数
显示全部学生信息

2.学生信息管理系统

a.学生信息维护

录入学生信息
删除学生信息
修改学生信息

b.查询/统计

按学生姓名/ID查找学生信息
统计学生总人数
显示全部学生信息

c.排序

根据某科成绩/总成绩升序/降序

3.业务流程

怎么用python写学生信息表 python学生信息录入系统_怎么用python写学生信息表

三、系统开发必备

1.开发环境

win10、python3.8.5解释器、Pycharm开发工具、Python内置模块os、re

2.目录

studentsys
	students.txt
	stusystem.py

四、主函数设计

怎么用python写学生信息表 python学生信息录入系统_java_02

def main():
    while True:
        men()
        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()


def men():
    print('===============学生信息管理系统功能菜单===============')
    print('1.录入学生信息')
    print('2.查找学生信息')
    print('3.删除学生信息')
    print('4.修改学生信息')
    print('5.排序')
    print('6.统计学生总人数')
    print('7.显示所有学生信息')
    print('0.退出系统')
    print('==================================================')


# 录入学生信息
def insert():
    pass


# 查找学生信息
def search():
    pass


# 删除学生信息
def delete():
    pass


# 修改学生信息
def modify():
    pass


# 排序
def sort():
    pass


# 统计学生总人数
def total():
    pass


# 显示所有学生信息
def show():
    pass


if __name__ == '__main__':
    main()

五、学生信息维护模块

1.录入学生信息功能

怎么用python写学生信息表 python学生信息录入系统_怎么用python写学生信息表_03

def insert():
    student_list = []
    while True:
        id = input('请输入ID(如1001):')
        if not id:
            break
        name = input('请输入姓名:')
        if not name:
            break

        try:
            english = int(input('请输入英语成绩:'))
            python = int(input('请输入Python成绩:'))
            java = int(input('请输入Java成绩:'))
        except:
            print('输入无效,不是整数类型,请重新输入')
            continue
        # 将录入的学生信息保存到字典中
        student={'id': id, 'name': name, 'english': english, 'python': python, 'java': java}
        # 将学生信息添加到列表中
        student_list.append(student)
        answer = input('是否继续添加?y/n\n')
        if answer == 'y':
            continue
        else:
            break

    # 调用save()函数
    save(student_list)
    print('学生信息录入完毕!!!')


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

2.删除学生信息功能

怎么用python写学生信息表 python学生信息录入系统_java_04

def delete():
    while True:
        student_id = input('请输入要删除学生的ID:')
        if student_id != '':
            if os.path.exists(filename):
                with open(filename,'r') as file:
                    student_old = file.readlines()
            else:
                student_old = []
            flag = True  # flag标记是否删除
            if student_old:
                with open(filename, 'w') 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\n')
            if answer == 'y':
                continue
            else:
                break

3.修改学生信息功能

怎么用python写学生信息表 python学生信息录入系统_python_05

def modify():
    show()
    if os.path.exists(filename):
        with open(filename,'r') as rfile:
            student_old = rfile.readlines()
    else:
        return
    student_id = input('请输入要修改学生的ID:')
    with open(filename,'w') as wfile:
        for item in student_old:
            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\n')
        if answer == 'y':
            modify()

六、查询/统计模块设计

1.查找学生信息功能

怎么用python写学生信息表 python学生信息录入系统_python_06

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') as rfile:
                student = rfile.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_student(student_query)
            # 请空列表
            student_query.clear()
            answer = input('是否要继续查询?y/n\n')
            if answer == 'y':
                continue
            else:
                break
        else:
            print('暂未保存学生信息')
            return

def show_student(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{:^6}\t{:^12}\t{:^14}\t{:^16}'
    for item in lst:
        print(format_data.format(item.get('id'),
                                 item.get('name'),
                                 item.get('english'),
                                 item.get('python'),
                                 item.get('java'),
                                 int(item.get('english'))+int(item.get('python'))+int(item.get('java'))
                                 ))

2.统计学生总人数

怎么用python写学生信息表 python学生信息录入系统_怎么用python写学生信息表_07

def total():
    if os.path.exists(filename):
        with open(filename,'r') as rfile:
            students = rfile.readlines()
            if students:
                print(f'一共有{len(students)}名学生')
            else:
                print('还没有录入学生信息')
    else:
        print('暂未保存数据信息')

3.显示所有信息功能

怎么用python写学生信息表 python学生信息录入系统_怎么用python写学生信息表_08

def show():
    student_list = []
    if os.path.exists(filename):
        with open(filename,'r') as rfile:
            students =rfile.readlines()
        for item in students:
            student_list.append(eval(item))
        if student_list:
            show_student(student_list)
    else:
        print('暂未保存数据信息!!!')

七、排序模块设计

怎么用python写学生信息表 python学生信息录入系统_python_09

def sort():
    show()
    if os.path.exists(filename):
        with open(filename,'r') as rfile:
            student_list = rfile.readlines()
        student_new = []
        for item in student_list:
            d = dict(eval(item))
            student_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成绩排序,0:按总成绩排序):')
    if mode == '1':
        student_new.sort(key=lambda x:int(x['english']),reverse=asc_or_desc_bool)
    elif mode == '2':
        student_new.sort(key=lambda x: int(x['python']), reverse=asc_or_desc_bool)
    elif mode == '3':
        student_new.sort(key=lambda x: int(x['java']), reverse=asc_or_desc_bool)
    elif mode == '0':
        student_new.sort(key=lambda x: int(x['english'])+int(x['python'])+int(x['java']), reverse=asc_or_desc_bool)
    else:
        print('您的输入有误,请重新输入')
        sort()
    show_student(student_new)

八、项目打包

1.Win + R快捷键打开“运行”对话框,输入cmd

怎么用python写学生信息表 python学生信息录入系统_java_10


2.在线安装pyinstaller:输入pip install PyInstaller

怎么用python写学生信息表 python学生信息录入系统_怎么用python写学生信息表_11

等几分钟…

3.执行打包:pyinstaller -F .py文件路径

怎么用python写学生信息表 python学生信息录入系统_python_12