Python练手项目-学生成绩管理系统

news2025/1/20 0:03:34

之前在最初的学习中,我就写过一个Python的学生管理系统,但是那个很粗糙,很简陋
今天在学习过程中,再次拿出来,重新优化书写
希望对初学者以及需要的朋友有帮助。

文章目录

    • 系统开发环境:
    • 1.实现功能
    • 2.系统设计
    • 3.主函数设计
    • 4.信息录入设计
    • 5.信息删除设计
    • 6.修改学生信息设计
    • 7.查找功能设计
    • 8.统计学生总数
    • 9.显示所有学生信息功能设计
    • 10.排序模块设计
    • 11.项目打包成.exe文件

系统开发环境:

  • 操作系统:win11
  • Python解释器版本:python3.10
  • 开发工具:Pychram
  • Python内置模块:os,re

1.实现功能

学生管理系统具备功能

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

2.系统设计

在这里插入图片描述

在这里插入图片描述
项目目录结构:
在这里插入图片描述

3.主函数设计

业务流程图:

在这里插入图片描述
功能设计:
在这里插入图片描述
实现代码:

def main():
    while True:
        menm()
        choice = 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:
                insret() # 录入学生信息
            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 menm():
    print('========================学生信息管理系统===================================')
    print('--------------------------功能菜单----------------------------------------')
    print('\t\t\t\t\t\t1.录入学生信息')
    print('\t\t\t\t\t\t2.查找学生信息')
    print('\t\t\t\t\t\t3.删除学生信息')
    print('\t\t\t\t\t\t4.修改学生信息')
    print('\t\t\t\t\t\t5.学生信息排序')
    print('\t\t\t\t\t\t6.统计学生总人数')
    print('\t\t\t\t\t\t7.显示所有学生信息')
    print('\t\t\t\t\t\t0.退出')

def insret():
    pass
def search():
    pass
def delete():
    pass
def modify():
    pass
def sort():
    pass
def total():
    pass
def show():
    pass
    
if __name__ == '__main__':
    main()

运行截图:
在这里插入图片描述

4.信息录入设计

从控制台录入学生信息,信息会被写入.txt文件
在这里插入图片描述
设计代码:

def insret():
    student_lst=[]
    while True:
        id=input('请输入ID(如01):')
        if not id:
            break
        name=input('请输入姓名:')
        if not name:
            break

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

    # 调用save()函数保存信息
    save(student_lst)
    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()

程序运行截图:
在这里插入图片描述

5.信息删除设计

在这里插入图片描述
设计代码:

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:
                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\n')
            if answer == 'y' or answer =='Y':
                continue
            else:
                break

程序运行界面:
在这里插入图片描述

6.修改学生信息设计

通过id的查询修改已经录入系统的信息,进行修改保存操作
在这里插入图片描述

代码设计:

def modify():
    show()
    if os.path.exists(filename):
        with open(filename,'r',encoding='utf-8') as rfile:
            student_old=rfile.readlines()
    else:
        return
    student_id=input('请输入要修改的学员的ID:')
    with open(filename,'w',encoding='utf-8') as wfile:
        for item in student_old:
            d = dict(eval(item))
            if d['id'] == student_id:
                print('找到学生信息,可以修改他的相关信息了!')
                while True:
                    try:
                        d['name'] = input('请输入姓名:')
                        d['math'] = 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' or answer == 'Y':
            modify()

运行截图:
在这里插入图片描述

7.查找功能设计

在这里插入图片描述
代码设计:

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 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' or 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{:^8}\t{:^10}\t{:^10}\t{:^8}'
    print(format_title.format('ID','姓名','数学成绩','英语成绩','Python成绩','java成绩','总成绩'))
    # 定义内容的格式显示
    format_data='{:^6}\t{:^12}\t{:^8}\t{:^8}\t{:^10}\t{:^10}\t{:^8}'
    for item in lst:
        print(format_data.format(item.get('id'),
                                 item.get('name'),
                                 item.get('math'),
                                 item.get('english'),
                                 item.get('python'),
                                 item.get('java'),
                                 int(item.get('english'))+int(item.get('math'))+int(item.get('python'))+int(item.get('java'))
                                 ))

运行截图:
在这里插入图片描述

8.统计学生总数

在这里插入图片描述
代码设计:

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

运行截图:
在这里插入图片描述

9.显示所有学生信息功能设计

在这里插入图片描述
代码设计:

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

运行截图:
在这里插入图片描述

10.排序模块设计

根据学生的成绩进行排序,包括升序降序
在这里插入图片描述
设计代码:

def sort():
    show()
    if os.path.exists(filename):
        with open(filename,'r',encoding='utf-8') 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.按照英语成绩排序 3.按照Python成绩排序 4.按照Java成绩排序 0.按照总成绩排序)')
    if mode=='1':
        student_new.sort(key=lambda x :int(x['math']),reverse=asc_or_desc_bool)
    elif mode=='2':
        student_new.sort(key=lambda x :int(x['english']),reverse=asc_or_desc_bool)
    elif mode=='3':
        student_new.sort(key=lambda x :int(x['python']),reverse=asc_or_desc_bool)
    elif mode=='4':
        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['java'])+int(x['python'])+int(x['english'])+int(x['math']),reverse=asc_or_desc_bool)
    else:
        print('您的输入有误,请重新输入!')
        sort()
    show_student(student_new)

代码运行截图:
在这里插入图片描述

11.项目打包成.exe文件

打包必要包:PyInstaller
控制台pip安装包
在这里插入图片描述
打包语法:pyinstaller -F .py(py文件所在路径)
上面是一个非常基础的打包方式,下面讲一个可以更改打包生成的图标方式

Pyinstaller -F -w -i [图片名].ico [脚本名].py

-w为控制是否打包控制台,即确定你打包形成的程序运行是否要出现黑框框,有gui界面记得加上:
-i[图片名]可以更改打包生成的图标,但是这个图片格式需要为.ico格式
常用图片转换网站:在线图片转icon格式
注:打包生成文件可能无法直接运行,相对路径在dist但是dist没有资源文件夹,我们应该新建一个文件,里面放入所有资源文件夹和exe文件

测试无误后压缩发给别人,别人解压后就可以使用了!

个人电脑打包演示:
在这里插入图片描述
打包成功:
在这里插入图片描述
在这里插入图片描述
这里我打包生成的程序都无法执行,我给student.txt文件复制进这个文件夹下就可以运行了,大家打包的时候注意!

好了,本次Python的学生管理系统就给大家写完了!感谢观看。
整理不易,点个赞再走吧!有需要源码可私信。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/719122.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

css3动画应用

按钮边框 按钮 首先实现正常边框按钮, 其次按钮相对定位,因为旋转的内容需要绝对定位, 旋转内容做伪元素处理,z-index设置负数是为了把按钮文字显示出来, 定位一半一半是把长方块中心点放按钮正中, 变形原…

照片jpg大小kb如何修改?图片在线压缩大小怎么处理?

最近需要在各种报名平台上传照片的小伙伴比较多,难免会遇到需要压缩jpg图片的情况,那么怎么才能将jpg图片压缩(https://www.yasuotu.com/jpg)呢?今天介绍一个图片在线压缩大小的方法,不用下载任何软件就可以…

内嵌 iframe 实现PDF预览

效果图如下&#xff1a; 代码如下&#xff1a; <template><div><!-- 控制浮层显示隐藏 --><el-button type"primary" size"small" class"btn" click"dialogVisible true">PDF 预览 (内嵌 iframe)</el-but…

pwn(7.4小学期)

Ret2libc 先查一下壳 32位&#xff0c;放入IDA中看看 查看一下 vulnerable_function();这个函数 Read函数&#xff0c;很明显的栈溢出 但是观察半天&#xff0c;发现这里并没有system函数 字符搜索我们看到了libc.so.6 可以想到libc函数库以及 PLT表中的代码会根据函数在…

[已成功破解] 阿里 taobao 滑条验证码 x5sec解密 slidedata参数

[已破解] 阿里 taobao 滑条验证码 x5sec解密 slidedata参数 今天在爬tb数据的时候 发现老是会触发一个滑块验证 只要过了这个滑块将滑块返回的x5secdata 的cookie 带到请求参数里面去 就能完美避开了 然后去抓了下滑块的包 过了这个滑块拿到cookie就能 访问阿里一直获取数据…

FPGA纯verilog实现UDP协议栈 AXIS用户接口,可替代Tri Mode Ethernet MAC,提供三套工程源码和技术支持

目录 1、前言2、我这里已有的UDP方案3、该UDP协议栈性能4、详细设计方案网络PHYRGMII转GMII模块AXIS FIFOUDP协议栈 5、vivado工程1-->B50610 工程6、vivado工程1-->RTL8211 工程7、vivado工程1-->88E1518 工程8、上板调试验证并演示准备工作查看ARPUDP数据回环测试 9…

1.5 基于MyBatis数据库逆向生成工具,并创建serverice和controller控制层

步骤1&#xff1a;在mybatis-generator中添加要生成的数据库表名 在genratorConfig.xml内容: <!-- 数据库表 --> <table tableName"stu"></table>步骤2&#xff1a;StuMapper.xml和StuMapper拷贝到对应的mapper模块下 步骤3&#xff1a;pojo对应…

计算机视觉颜色校正方法

计算机视觉颜色校正方法 调色和色彩矫正之间的区别直方图均衡化原理实现代码 CCM颜色校正矩阵原理 深度学习Deep_White_Balance什么是sRGB图像问题描述&#xff1a;方法概述&#xff1a;模型架构&#xff1a;训练损失函数实现快速开始 调色和色彩矫正之间的区别 调色是指通过调…

Vue3使用element-plus实现弹窗效果-demo

使用 <ShareDialog v-model"isShow" onChangeDialog"onChangeDialog" /> import ShareDialog from ./ShareDialog.vue; const isShow ref(false); const onShowDialog (show) > {isShow.value show; }; const onChangeDialog (val) > {co…

使用AI人工智能给线稿上色,给漫画上色

【深度学习】AIGC &#xff0c;ControlNet 论文中的图。 一些酷炫的可以做纵深领域的图&#xff0c;这里再放一下。 下图是由手绘草稿给出图&#xff1a; 由线稿得到图&#xff0c;给漫画上色&#xff1a;

简单的PWN学习-ret2shellcode

最近笔者开始钻研pwn的一些知识&#xff0c;发现栈溢出真的非常的有意思&#xff0c;于是经过一个多礼拜的学习&#xff0c;终于是把2016年的一道CTF题给看明白了了&#xff0c;首先我们学习一下前置技能 0x01 shellcode​ 首先简单看一下shellcode是怎么生成的&#xff0c;首…

Linux和Windows两种平台安装Maven

Linux和Windows两种平台安装Maven 0. 写在前面 Linux版本&#xff1a;Centos-7.5Windows版本&#xff1a;Windows10Maven版本&#xff1a;Maven-3.5.4JDK版本&#xff1a;jdk1.8 1. Linux平台安装 1.1 查看Linux内核版本命令 查看Linux内核版本命令 [whybigdatanode02 ~]$ …

AI医疗。

随着技术的发展&#xff0c;人工智能&#xff08;AI&#xff09;已经渗透到了我们生活的许多领域&#xff0c;包括凭其强大的预测和分析能力已经走入了医疗卫生领域。特别是在使用OpenAI的GPT-4技术的chatbot&#xff0c;如chatGPT和GPT-4等&#xff0c;已经成为了给医疗行业注…

驾驶舱数据指标体系设计指南

大数据时代下&#xff0c;各行各业面对众多的顾客和复杂多变的市场需求&#xff0c;要想及时适应市场变化&#xff0c;掌握市场动态&#xff0c;就需要对各个环节的数据进行分析&#xff0c;得到科学有效的结论来指导决策&#xff0c;这就离不开领导驾驶舱。 一、领导驾驶舱是什…

记一次 .NET 某工控视觉系统 卡死分析

一&#xff1a;背景 1. 讲故事 前段时间有位朋友找到我&#xff0c;说他们的工业视觉软件僵死了&#xff0c;让我帮忙看下到底是什么情况&#xff0c;哈哈&#xff0c;其实卡死的问题相对好定位&#xff0c;无非就是看主线程栈嘛&#xff0c;然后就是具体问题具体分析&#x…

为生信写的Python简明教程 | 视频7

开源生信 Python教程 生信专用简明 Python 文字和视频教程 源码在&#xff1a;https://github.com/Tong-Chen/Bioinfo_course_python 目录 背景介绍 编程开篇为什么学习Python如何安装Python如何运行Python命令和脚本使用什么编辑器写Python脚本Python程序事例Python基本语法 数…

BurpSutie拓展插件推荐-辅助测试插件

为方便您的阅读&#xff0c;可点击下方蓝色字体&#xff0c;进行跳转↓↓↓ 01 chunked-coding-converter-0.4.0&#xff08;1&#xff09;工具介绍&#xff08;2&#xff09;下载地址&#xff08;3&#xff09;使用说明 02 captcha-killer&#xff08;1&#xff09;工具介绍&a…

HOT43-验证二叉搜索树

leetcode原题链接&#xff1a;验证二叉搜索树 题目描述 给你一个二叉树的根节点 root &#xff0c;判断其是否是一个有效的二叉搜索树。 有效 二叉搜索树定义如下&#xff1a; 节点的左子树只包含 小于 当前节点的数。节点的右子树只包含 大于 当前节点的数。所有左子树和右…

tty(三)uart框架分析

基于linux-3.14.16 重点文件&#xff1a;serial_core.c 一、基本数据结构和接口 这里显然是导出符号给需要用到uart核心的代码使用的&#xff0c;我们从uart_register_driver和uart_add_one_port来分析&#xff0c;搞清楚uart和tty核心的关系。 二、uart_register_driver 首…

服务案例|消失的Linux定时清除任务

企业数字化转型&#xff0c;应用软件不断升级&#xff0c;对运行环境的要求也越来越高&#xff0c;CPU、内存等硬件也同步进入升级。当业务运行或备份时&#xff0c;将产生大量历史文件和临时文件&#xff0c;这就是在运维检测中&#xff0c;我们常看到文件每天几个G&#xff0…