栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 前沿技术 > 大数据 > 大数据系统

python项目:学生管理系统(文件链接版)

python项目:学生管理系统(文件链接版)

学生管理系统
  • 一、程序功能(Function)
    • 1、功能概述
    • 2、思维导图
  • 二、学生实体(Entity)
    • 1、思维导图
    • 2、关系模式
    • 3、学生表
    • 4、操作问题
  • 三、构造系统框架
    • 1、创建主程序
    • 2、建立主菜单
    • 3、建立二级菜单
    • 4、利用Python将程序链接到学生信息文件
      • (1)打开、关闭文件,并打印内容
      • (2)将(1)运用到系统中
  • 四、对学生管理系统中的数据进行操作
    • 1、增加学生记录
    • 2、查询学生记录
      • (1)查询全部学生记录
      • (2)按学号查询学生记录
      • (3)按姓名查询学生记录
    • 3、修改学生信息
    • 4、删除学生信息
  • 五、完整代码
  • 六、总结
    • 1、关于该系统现存在的问题
    • 2、学习总结

一、程序功能(Function) 1、功能概述

利用Python完成一个学生信息的增删改查程序,主要涉及知识点:程序控制结构(实现可进可退的多级菜单)、文件读写操作(学生信息要保存到磁盘上的文件里)、利用函数实现功能模块化。

2、思维导图
  • 百度脑图
    https://naotu.baidu.com/
    创建自己的思维导图,整理思绪,更有利于创建项目。
二、学生实体(Entity) 1、思维导图

2、关系模式
  • 学生(学号, 姓名, 性别, 年龄, 班级, 专业, 系部, 电话)
3、学生表
  • 行——记录——元组
  • 列——字段——属性
  • 先将学生信息保存到文本文件里,用空格来隔开每个字段。
2021001 李晓红 女 19 2021级软件4班 软件技术 人工智能与大数据学院 15945456780
2021002 王晓刚 男 18 2021级软件4班 软件技术 人工智能与大数据学院 13890904567
2021003 唐雨涵 女 19 2021级软件4班 软件技术 人工智能与大数据学院 18878789023
2021101 张三丰 男 18 2021级大数据1班 大数据技术 人工智能与大数据学院 15945456780
2021102 肖雨林 男 18 2021级大数据1班 大数据技术 人工智能与大数据学院 18890904560
2021103 郑小翠 女 19 2021级大数据1班 大数据技术 人工智能与大数据学院 15890904567

4、操作问题
  • 这里在保存文件的时候需要将编码改为ANSI,不然将会出现错误。
三、构造系统框架 1、创建主程序

  • 效果图
  • 代码
# 主程序
while True:
    print('用户登录')
    print('==========')
    print('1.登录')
    print('2.退出')
    print('==========')
    mc1 = int(input('输入菜单号: '))
    if mc1 == 1:
        print('成功登入!')
    elif mc1 == 2:
        print('n谢谢使用本程序n')
        break
2、建立主菜单
  • 运用def定义函数定义学生管理系统主菜单,并调用。运行程序,查看结果。
3、建立二级菜单
  • 运用def定义函数创建学生管理系统二级菜单并调用。

  • 运行程序,查看结果

4、利用Python将程序链接到学生信息文件 (1)打开、关闭文件,并打印内容
  • 通过open()函数打开s_list.txt学生信息文件,并进行打印。
  • f.close()打印学生信息后将文件关闭
  • 运行程序,查看结果。
  • 输出数据看似排列整齐,但当列宽改变时,数据位置也会跟着改变。
(2)将(1)运用到系统中
  • 利用def定义函数,将(1)中的内容定义到学生管理系统中,便于随时调用。
  • 将(1)中函数定义为get_all_students()函数,方便之后调用。
  • return()函数返回所有学生信息,即其上一组函数所得到的结果。
四、对学生管理系统中的数据进行操作 1、增加学生记录
  • 定义add_student()函数,并调用。
  • 运行查看结果,并录入新的信息。
2、查询学生记录 (1)查询全部学生记录
  • 进行测试
  • 运行程序查看结果
  • 测试成功!将利用id查询学生信息的代码利用def定义,并应用到学生管理系统中。
  • 定义disaplay_all_students()函数

  • 调用disaplay_all_students()函数
  • 运行程序,查看结果
  • 测试成功。
(2)按学号查询学生记录
  • 进行测试
  • 运行程序,查看结果
  • 发现添加记录成功了!将利用id查询学生信息的代码利用def定义,并应用到学生管理系统中。
  • 运行程序,查看结果。
  • 程序运行成功!
(3)按姓名查询学生记录
  • 进行测试
  • 运行程序,查看结果
  • 测试成功!
  • 运用到学生管理系统中。
3、修改学生信息
  • 进行测试
  • 运行程序,查看结果
  • 测试成功,进行下一步,将该段程序定义为学生管理系统中的modify_student()函数。
4、删除学生信息
  • 进行测试
  • 运行程序,查看结果
  • 测试成功
  • 定义函数,放入学生管理系统中

  • 学生管理系统成功完成。
  • 现在还是一个简陋的一个程序,还有许多需要改进的地方,需要慢慢改进,如果有好的建议,评论区见,谢谢!
五、完整代码
def get_all_students():
    students = []
    f = open('s_list.txt')
    for line in f:
        line = line.replace('n', '')
        student = line.split(' ')
        students.append(student)
    f.close()
    return students

def add_student():  # 添加学生信息
    students = get_all_students()
    id = input('学号: ')
    name = input('姓名: ')
    sex = input('性别: ')
    age = input('年龄: ')
    grade_class = input('班级: ')
    major = input('专业: ')
    college = input('学院: ')
    phone_number = input('电话号码: ')

    students.append([id, name, sex, age, grade_class, major, college, phone_number])

    f = open('s_list.txt', 'w')
    for i in range(len(students)):
        student = ' '.join(students[i]) + 'n'
        f.write(student)
    f.close()
    print('学生记录添加成功!')
    
def disaplay_all_students():  # 查询所有学生信息
    students = get_all_students()
    for i in range(len(students)):
        for j in  range(len(students[i])):
            print(students[i][j], end=' ')
        print()
    
    
def id_disaplay_student():  # 以学号查询学生信息
    id = input('学号: ')
    found = False
    students = get_all_students()
    for i in range(len(students)):
        if (students[i][0] == id):
            found =True
            for j in range(len(students[i])):
                print(students[i][j], end=' ')
            break
    if not found:
        print(f'学生信息中没有学号为{id}的学生!')

def name_disaply_student():   # 以姓名查询学生信息
    name = input('姓名: ')
    students = get_all_students()
    found = False
    for i in range(len(students)):
        if (students[i][1] == name):
            found = True
            for j in range(len(students[i])):
                print(students[i][j], end=' ')
            break
    if not found:
        print(f'学生信息中没有姓名为{name}的学生!')

def query_student():  # 查询学生记录
    while True:
        print('n查询学生记录n')
        print('=================')
        print('1.按学号查询学生记录')
        print('2.按姓名查询学生记录')
        print('3.查询全部学生记录')
        print('4.返回上级菜单')
        print('=================')
        mc3 = int(input('输入菜单号:'))
        if mc3 == 1:
            id_disaplay_student()
        elif mc3 == 2:
            name_disaply_student()
        elif mc3 == 3:
            disaplay_all_students()
        else:
            break
        
def modify_student():  # 修改学生信息
    students = get_all_students()
    id = input('需要修改信息的学生的学号: ')
    new_name = input('姓名: ')
    new_sex = input('性别: ')
    new_age = input('年龄: ')
    new_grade_class = input('班级: ')
    new_major = input('专业: ')
    new_college = input('学院: ')
    new_phone_number = input('电话号码: ')
    
    found = False
    for i in range(len(students)):
        if (students[i][0] == id):
            found = True
            students[i][1] = new_name
            students[i][2] = new_sex
            students[i][3] = new_age
            students[i][4] = new_grade_class
            students[i][5] = new_major
            students[i][6] = new_college
            students[i][7] = new_phone_number
            print('修改成功!')
            for j in range(len(students[i])):
                print(students[i][j], end=' ')
            break
    if not found:
        print(f'学生信息中没有学号为{id}的学生!')
    
    f = open('s_list.txt', 'w')
    for i in range(len(students)):
        student = ' '.join(students[i]) + 'n'
        f.write(student)
    f.close()

def delete_student():
    students = get_all_students()
    id = input('输入要删除信息的学生的学号:')
    found = False
    for i in range(len(students)):
        if (students[i][0] == id):
            found = True
            break
    if not found:
        print(f'学生信息中没有学号为{id}的学生!')
    else:
        del students[i]
        print(f'学号为{id}的信息已成功删除!')
    f = open('s_list.txt', 'w')
    for i in range(len(students)):
        student = ' '.join(students[i]) + 'n'
        f.write(student)
    f.close()

def login():
    username = input('输入用户名: ')
    password = input('输入密码: ')
    if username == 'zl' and password == '202111':
        while True:
            print('n学生信息管理n')
            print('===========')
            print('1. 添加学生记录')
            print('2. 查询学生记录')
            print('3. 修改学生记录')
            print('4. 删除学生记录')
            print('5. 返回上级菜单')
            print('===========')
            mc2 = int(input('输入菜单号: '))
            if mc2 == 1:
                add_student()
            elif mc2 == 2:
                query_student()
            elif mc2 == 3:
                 modify_student()
            elif mc2 == 4:
                 delete_student()
            else:
                break
    else:
        print('n用户名或密码错误,请重新登录n')

# 主程序
while True:
    print('用户登录')
    print('==========')
    print('1.登录')
    print('2.退出')
    print('==========')
    mc1 = int(input('输入菜单号: '))
    if mc1 == 1:
        login()
    elif mc1 == 2:
        print('n谢谢使用本程序n')
        break
六、总结 1、关于该系统现存在的问题
  • 1.关于登录界面,当输入字符时会报错,这个问题可以将代码改为:
while True:
    print('用户登录')
    print('==========')
    print('1.登录')
    print('2.退出')
    print('==========')
    mc1 = input('输入菜单号: ')
    if mc1 == str(1):
        login()
    elif mc1 == str(2):
        print('n谢谢使用本程序n')
        break
    elif mc1 != 1 or mc1 != 2:
        print('请输入正确的菜单号!')
  • 2、修改学生记录还可以按照其他字段的信息修改,也可以单独修改一个字段的信息。
    ……
  • 该系统现在还是一个简陋的程序,还有许多需要改进的地方,需要慢慢改进,如果有好的建议,评论区见,谢谢!
2、学习总结
  • 书写程序时需要有一个好的思路,这样有利于对整个系统结构结构框架进行构建。
  • 在写程序时,为防止出错找不到原因,可以先打开另一个页面,进行代码测试,书写正确后在放入主程序,这样可以高效避免错误发生。
  • 书写程序需要有一个清晰的头脑,所以一定要注意休息。
  • 学习python不是一天两天的事,要懂得《劝学》中的“锲而舍之,朽木不折;锲而不舍,金石可镂”
  • 注意:Road in the foot!!!
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/687272.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号