基于Python的学生成绩管理系统


一、项目介绍

网络技术的快速发展给各行各业带来了很大的突破,也给各行各业提供了一种新的管理模块,对于学生成绩管理系统将是又一个传统管理到智能化信息管理的改革,对于传统的学生成绩管理,所包括的信息内容比较多,对于用户想要对这些数据进行管理维护需要花费很大的时间信息,而且对于数据的存储比较麻烦,想要查找某一相关的数据信息比较繁琐。
本文研究的系统是以Python为语言的学生成绩管理系统设计与实现,它在使用时数据库和程序不会被造成太大的影响,用起来也很得心应手。它也算是当时比较流行的安全性相对也很高的框架之一了,Python开发语言。和mysql数据库,最终完成学生成绩管理系统。

二、开发环境

开发语言:Python
python框架:django
软件版本:python3.7/python3.8
数据库:mysql 5.7或更高版本
数据库工具:Navicat11
开发软件:PyCharm/vs code
前端框架:vue.js

————————————————

三、功能介绍

1.登录页面

账号(文本框)判断输入的是否正确或者合法,非空判断等,给出提示
密码(文本框)同上
记住密码(功能)
教师 学生 管理员(三种身份)
登录按钮(判断账号是否存在,账号密码是否正确)

2.学生注册页面

账号(输入学号注册,每个学号只能注册一次,若不是学号,则无法注册成功)
密码(同上)
注册按钮(非空判断,判断是否为学号)
弹出注册成功,并返回登录页面

3.管理员页面

在这里插入图片描述

4.教师页面
在这里插入图片描述

5.学生页面
在这里插入图片描述

四、核心代码

部分代码:


def users_login(request):
    if request.method in ["POST", "GET"]:
        msg = {'code': normal_code, "msg": mes.normal_code}
        req_dict = request.session.get("req_dict")
        if req_dict.get('role')!=None:
            del req_dict['role']
        datas = users.getbyparams(users, users, req_dict)
        if not datas:
            msg['code'] = password_error_code
            msg['msg'] = mes.password_error_code
            return JsonResponse(msg)

        req_dict['id'] = datas[0].get('id')
        return Auth.authenticate(Auth, users, req_dict)


def users_register(request):
    if request.method in ["POST", "GET"]:
        msg = {'code': normal_code, "msg": mes.normal_code}
        req_dict = request.session.get("req_dict")

        error = users.createbyreq(users, users, req_dict)
        if error != None:
            msg['code'] = crud_error_code
            msg['msg'] = error
        return JsonResponse(msg)


def users_session(request):
    '''
    '''
    if request.method in ["POST", "GET"]:
        msg = {"code": normal_code,"msg":mes.normal_code, "data": {}}

        req_dict = {"id": request.session.get('params').get("id")}
        msg['data'] = users.getbyparams(users, users, req_dict)[0]

        return JsonResponse(msg)


def users_logout(request):
    if request.method in ["POST", "GET"]:
        msg = {
            "msg": "退出成功",
            "code": 0
        }

        return JsonResponse(msg)


def users_page(request):
    '''
    '''
    if request.method in ["POST", "GET"]:
        msg = {"code": normal_code, "msg": mes.normal_code,
               "data": {"currPage": 1, "totalPage": 1, "total": 1, "pageSize": 10, "list": []}}
        req_dict = request.session.get("req_dict")
        tablename = request.session.get("tablename")
        try:
            __hasMessage__ = users.__hasMessage__
        except:
            __hasMessage__ = None
        if __hasMessage__ and __hasMessage__ != "否":

            if tablename != "users":
                req_dict["userid"] = request.session.get("params").get("id")
        if tablename == "users":
            msg['data']['list'], msg['data']['currPage'], msg['data']['totalPage'], msg['data']['total'], \
            msg['data']['pageSize'] = users.page(users, users, req_dict)
        else:
            msg['data']['list'], msg['data']['currPage'], msg['data']['totalPage'], msg['data']['total'], \
            msg['data']['pageSize'] = [],1,0,0,10

        return JsonResponse(msg)


五、效果图

请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述

六、文章目录

目 录
摘 要 I
ABSTRACT II
目 录 II
第1章 绪论 1
1.1背景及意义 1
1.2 国内外研究概况 1
1.3 研究的内容 1
第2章 相关技术 3
2.1 Python简介 4
2.2 Django 框架介绍 6
2.3 B/S结构 4
2.4 MySQL数据库 4
第3章 系统分析 5
3.1 需求分析 5
3.2 系统可行性分析 5
3.2.1技术可行性:技术背景 5
3.2.2经济可行性 6
3.2.3操作可行性: 6
3.3 项目设计目标与原则 6
3.4系统流程分析 7
3.4.1操作流程 7
3.4.2添加信息流程 8
3.4.3删除信息流程 9
第4章 系统设计 11
4.1 系统体系结构 11
4.2开发流程设计系统 12
4.3 数据库设计原则 13
4.4 数据表 15
第5章 系统详细设计 19
5.1管理员功能模块 20
5.2用户功能模块 23
5.3前台功能模块 19
第6章 系统测试 25
6.1系统测试的目的 25
6.2系统测试方法 25
6.3功能测试 26
结 论 28
致 谢 29

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
本系统主要用于学校学生信息管理,总体任务是实现学生信息关系的系统化、规范化和自动化,其主要任务是用计算机对学生各种信息进行日常管理,如查询、修改 、增加、删除,另外还考虑到学生选课,针对这些要求设计了学生信息管理系统;本系统主要用于学校学生信息管理,总体任务是实现学生信息关系的系统化、规范化和自动化,其主要任务是用计算机对学生各种信息进行日常管理,如查询、修改 、增加、删除,另外还考虑到学生选课,针对这些要求设计了学生信息管理系统。 本系统主要包括学生信息查询、教务信息维护和学生选课三部分。其功能主要有: 1、有关学籍等信息的输入,包括输入学生基本信息、所在班级、所学课程和成绩等。 2、学生信息的查询,包括查询学生基本信息、所在班级、已学课程和成绩等。 3、学生信息的修改。 4、班级管理信息的输入,包括输入班级设置、年级信息等。 5、班级管理信息的查询。 6、班级管理信息的修改。 7、学生课程的设置和修改。 学生信息管理系统是典型的信息管理系统 (MIS),其开发主要包括后台数据库的建立和维护以及前端应用程序的开发两个方面。对于前者要求建立起数据一致性和完整性强、数据安全性好的库。而对于后者则要求应用程序功能完备,易使用等特点。 经过分析,我们使用MICROSOFT公司的VISUAL BASIC开发工具,利用其提供的各种面向对象的开发工具,尤其是数据窗口这一能方便而简洁操纵数据库的智能化对象,首先在短时间内建立系统应用原型,然后,对初始原型系统进行需求迭代,不断修正和改进,直到形成用户满意的可行系统。 关键字:控件、窗体、域、数据库
学生成绩管理系统是一种非常常见的应用。Python 是一种非常流行的编程语言,因此使用 Python开发学生成绩管理系统是非常可行的。下面是一个简单的学生成绩管理系统的实现: 1. 首先定义一个 Student 类,用来表示每个学生的信息,包括姓名、学号、年级和成绩等属性。 ```python class Student: def __init__(self, name, id, grade, score): self.name = name self.id = id self.grade = grade self.score = score ``` 2. 然后定义一个 GradeBook 类,用来管理所有的学生信息,包括添加学生、删除学生、查询学生信息、计算平均成绩等方法。 ```python class GradeBook: def __init__(self): self.students = [] def add_student(self, student): self.students.append(student) def remove_student(self, student): self.students.remove(student) def find_student_by_id(self, id): for student in self.students: if student.id == id: return student return None def find_student_by_name(self, name): for student in self.students: if student.name == name: return student return None def calculate_average_score(self): total_score = 0 for student in self.students: total_score += student.score return total_score / len(self.students) ``` 3. 最后,可以编写一个简单的交互式命令行界面,用来操作学生成绩管理系统。 ```python def main(): grade_book = GradeBook() while True: print("学生成绩管理系统") print("1. 添加学生") print("2. 删除学生") print("3. 查询学生信息") print("4. 计算平均成绩") print("5. 退出") choice = int(input("请选择操作: ")) if choice == 1: name = input("请输入学生姓名: ") id = input("请输入学生学号: ") grade = input("请输入学生年级: ") score = float(input("请输入学生成绩: ")) student = Student(name, id, grade, score) grade_book.add_student(student) print("学生添加成功!") elif choice == 2: id = input("请输入要删除的学生学号: ") student = grade_book.find_student_by_id(id) if student: grade_book.remove_student(student) print("学生删除成功!") else: print("未找到该学生!") elif choice == 3: id_or_name = input("请输入要查询的学生学号或姓名: ") student = grade_book.find_student_by_id(id_or_name) or grade_book.find_student_by_name(id_or_name) if student: print("姓名: ", student.name) print("学号: ", student.id) print("年级: ", student.grade) print("成绩: ", student.score) else: print("未找到该学生!") elif choice == 4: average_score = grade_book.calculate_average_score() print("平均成绩: ", average_score) elif choice == 5: break else: print("无效操作,请重新选择!") if __name__ == "__main__": main() ``` 这样,一个简单的学生成绩管理系统就完成了。当然,这只是一个简单的示例,实际开发中需要考虑更多的功能和异常情况。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

qq_1406299528

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值