IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> python项目:学生管理系统(文件链接版) -> 正文阅读

[大数据]python项目:学生管理系统(文件链接版)

一、程序功能(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!!!
  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2021-12-28 22:59:50  更:2021-12-28 22:59:53 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/17 3:40:26-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码