【Python】python学生体能考核成绩管理系统(数据库) (源码+报告)【独一无二】

本文主要是介绍【Python】python学生体能考核成绩管理系统(数据库) (源码+报告)【独一无二】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

请添加图片描述


👉博__主👈:米码收割机
👉技__能👈:C++/Python语言
👉公众号👈:测试开发自动化【获取源码+商业合作】
👉荣__誉👈:阿里云博客专家博主、51CTO技术博主
👉专__注👈:专注主流机器人、人工智能等相关领域的开发、测试技术。


系列文章目录


目录

  • 系列文章目录
  • 一、设计目的
  • 二、数据库设计
  • 三、运行结果
    • 3.1. 教师登录
    • 3.2. 录入成绩
    • 3.3. 修改成绩
    • 3.4. 删除成绩
    • 3.5. 返回主菜单
    • 3.6. 学生查询
    • 3.7. 查询结果
  • 四、代码分析
      • 1. 导入模块
      • 2. 数据库连接
      • 3. 创建数据库表
        • 3.1 用户数据表
        • 3.2 体能数据表
      • 4. 用户登录
      • 5. 学生查询功能
      • 6. 老师录入和修改数据
      • 7. 主菜单和程序入口
      • 8. 关闭数据库连接


一、设计目的

学生体能考核成绩管理系统是一个综合性的教育领域课程实验,旨在帮助学生掌握数据库管理和应用、身份认证与权限控制、问题解决能力以及综合性项目开发等关键技能。这个实验设计具有多重目的,旨在为学生提供全面的学习体验和职业技能培养。

首先,实验的一个重要目标是让学生实践数据库管理与应用。通过使用Python编程语言和MySQL数据库,学生学会了如何创建数据库表、插入、查询、更新和删除数据等数据库操作。这不仅提供了数据库管理技能的实际应用,还为学生提供了处理大量数据的经验。

其次,实验着重关注身份认证和权限控制的重要性。学生需要实现用户登录功能,并根据用户类型(学生或老师)设置不同的权限。这有助于他们理解在应用程序中如何实施基本的安全措施,以确保数据的安全性和保密性。

👉👉👉 源码获取 关注【测试开发自动化】公众号,回复 “ 体能考核系统 ” 获取。👈👈👈

第三,这个实验项目提供了一个综合性项目开发的机会。学生需要将不同的功能模块组合在一起,创建一个完整的应用程序。这锻炼了他们将理论知识应用到实际项目中的能力,培养了他们的软件开发技能。

此外,实验的背景是体育成绩管理应用,为学生提供了一个实际场景,展示了编程和数据库管理在教育领域的应用。学生可以体验到如何将技术与教育管理相结合,提高了他们的综合素质。

👉👉👉 源码获取 关注【测试开发自动化】公众号,回复 “ 体能考核系统 ” 获取。👈👈👈


二、数据库设计

数据库中包括两个表格:user表格和fitness_data表格。下面是这两个表格的字段表格以及建立数据库的过程的详细分析。

  1. user 表格字段表格:
字段名数据类型说明
idINT (自增主键) 用户的唯一标识
usernameVARCHAR(255) NOT NULL用户的用户名
passwordVARCHAR(255) NOT NULL用户的密码
user_typeENUM(‘teacher’, ‘student’) NOT NULL用户类型,可选值为老师或学生
  1. fitness_data 表格字段表格:
字段名数据类型说明
idINT (自增主键)体能数据记录的唯一标识
student_nameVARCHAR(255) NOT NULL学生的姓名
push_upsINT俯卧撑成绩
sit_upsINT仰卧起坐成绩
pull_upsINT引体向上成绩
run_3000mTIME3000米跑成绩(时间格式:HH:MM:SS)

👉👉👉 源码获取 关注【测试开发自动化】公众号,回复 “ 体能考核系统 ” 获取。👈👈👈


三、运行结果

3.1. 教师登录

在这里插入图片描述

3.2. 录入成绩

在这里插入图片描述

3.3. 修改成绩

在这里插入图片描述

👉👉👉 源码获取 关注【测试开发自动化】公众号,回复 “ 体能考核系统 ” 获取。👈👈👈

3.4. 删除成绩

在这里插入图片描述

3.5. 返回主菜单

在这里插入图片描述

3.6. 学生查询

在这里插入图片描述

👉👉👉 源码获取 关注【测试开发自动化】公众号,回复 “ 体能考核系统 ” 获取。👈👈👈

3.7. 查询结果

在这里插入图片描述


四、代码分析

1. 导入模块

import pymysql
  • 导入 pymysql 模块:此模块用于在Python中提供MySQL数据库的连接和操作功能,是实现数据库操作的基础。

2. 数据库连接

conn = pymysql.connect(host='127.0.0.1',user='root',password='root',db='dish'
)

👉👉👉 源码获取 关注【测试开发自动化】公众号,回复 “ 体能考核系统 ” 获取。👈👈👈

  • 建立数据库连接:这部分代码负责建立与MySQL数据库的连接。指定了数据库的位置(本地主机)、用户名、密码以及要操作的数据库名。

3. 创建数据库表

3.1 用户数据表
def create_user_table():cursor = conn.cursor()cursor.execute('''CREATE TABLE IF NOT EXISTS user (id INT AUTO_INCREMENT PRIMARY KEY,# 略.....)''')conn.commit()cursor.close()
  • 定义函数 create_user_table:该函数用于创建一个新的用户表,存储用户的ID、用户名、密码和用户类型(教师或学生)。
  • 使用事务处理:通过conn.commit()来提交SQL命令,确保创建表的操作被正确执行。
3.2 体能数据表
def create_fitness_table():cursor = conn.cursor()cursor.execute('''CREATE TABLE IF NOT EXISTS fitness_data (id INT AUTO_INCREMENT PRIMARY KEY,# 略.....)''')conn.commit()cursor.close()
  • 定义函数 create_fitness_table:创建一个表来存储学生的体能测试数据,包括俯卧撑、仰卧起坐、引体向上以及3000米跑的成绩。

4. 用户登录

def user_login():username = input("请输入用户名: ")password = input("请输入密码: ")cursor = conn.cursor()cursor.execute("SELECT user_type FROM user WHERE username=%s AND password=%s", (username, password))user_type = cursor.fetchone()cursor.close()if user_type:return user_type[0]else:return None
  • 用户验证:通过输入用户名和密码进行用户验证,并从数据库中检索对应的用户类型(学生或教师),若验证成功返回用户类型,否则返回None

👉👉👉 源码获取 关注【测试开发自动化】公众号,回复 “ 体能考核系统 ” 获取。👈👈👈

5. 学生查询功能

def student_query():# 略.....
  • 个人及不及格学生成绩查询:学生可以查询自己的体能成绩或查看不及格的学生名单。这部分代码通过不同的选择来执行不同的数据库查询操作。

6. 老师录入和修改数据

def teacher_input_and_modify():# 略.....
  • 数据录入和修改:教师可以录入、修改或删除学生的体能数据。此功能允许教师通过菜单进行选择并执行相应的数据库操作。

7. 主菜单和程序入口

def main_menu():...
if __name__ == "__main__":create_user_table()create_fitness_table()main_menu()
  • 主菜单循环:程序的主入口点,包括用户表和体能数据表的创建及主菜单的调用,主菜单控制程序的主要流程,允许用户进行不同的操作选择。

8. 关闭数据库连接

conn.close()
  • 释放资源:在程序结束时关闭数据库连接,确保所有的资源被妥善释放。

整个代码结构清晰,逻辑分明,每个功能模块都具有明确的职责,从数据库连接到数据操作再到用户交互,形成了一个完整的体能数据管理系统。

👉👉👉 源码获取 关注【测试开发自动化】公众号,回复 “ 体能考核系统 ” 获取。👈👈👈

这篇关于【Python】python学生体能考核成绩管理系统(数据库) (源码+报告)【独一无二】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/896913

相关文章

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

python: 多模块(.py)中全局变量的导入

文章目录 global关键字可变类型和不可变类型数据的内存地址单模块(单个py文件)的全局变量示例总结 多模块(多个py文件)的全局变量from x import x导入全局变量示例 import x导入全局变量示例 总结 global关键字 global 的作用范围是模块(.py)级别: 当你在一个模块(文件)中使用 global 声明变量时,这个变量只在该模块的全局命名空

MySQL数据库宕机,启动不起来,教你一招搞定!

作者介绍:老苏,10余年DBA工作运维经验,擅长Oracle、MySQL、PG、Mongodb数据库运维(如安装迁移,性能优化、故障应急处理等)公众号:老苏畅谈运维欢迎关注本人公众号,更多精彩与您分享。 MySQL数据库宕机,数据页损坏问题,启动不起来,该如何排查和解决,本文将为你说明具体的排查过程。 查看MySQL error日志 查看 MySQL error日志,排查哪个表(表空间

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟 开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚 第一站:海量资源,应有尽有 走进“智听

【专题】2024飞行汽车技术全景报告合集PDF分享(附原数据表)

原文链接: https://tecdat.cn/?p=37628 6月16日,小鹏汇天旅航者X2在北京大兴国际机场临空经济区完成首飞,这也是小鹏汇天的产品在京津冀地区进行的首次飞行。小鹏汇天方面还表示,公司准备量产,并计划今年四季度开启预售小鹏汇天分体式飞行汽车,探索分体式飞行汽车城际通勤。阅读原文,获取专题报告合集全文,解锁文末271份飞行汽车相关行业研究报告。 据悉,业内人士对飞行汽车行业

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

【机器学习】高斯过程的基本概念和应用领域以及在python中的实例

引言 高斯过程(Gaussian Process,简称GP)是一种概率模型,用于描述一组随机变量的联合概率分布,其中任何一个有限维度的子集都具有高斯分布 文章目录 引言一、高斯过程1.1 基本定义1.1.1 随机过程1.1.2 高斯分布 1.2 高斯过程的特性1.2.1 联合高斯性1.2.2 均值函数1.2.3 协方差函数(或核函数) 1.3 核函数1.4 高斯过程回归(Gauss

【学习笔记】 陈强-机器学习-Python-Ch15 人工神经网络(1)sklearn

系列文章目录 监督学习:参数方法 【学习笔记】 陈强-机器学习-Python-Ch4 线性回归 【学习笔记】 陈强-机器学习-Python-Ch5 逻辑回归 【课后题练习】 陈强-机器学习-Python-Ch5 逻辑回归(SAheart.csv) 【学习笔记】 陈强-机器学习-Python-Ch6 多项逻辑回归 【学习笔记 及 课后题练习】 陈强-机器学习-Python-Ch7 判别分析 【学

Java ArrayList扩容机制 (源码解读)

结论:初始长度为10,若所需长度小于1.5倍原长度,则按照1.5倍扩容。若不够用则按照所需长度扩容。 一. 明确类内部重要变量含义         1:数组默认长度         2:这是一个共享的空数组实例,用于明确创建长度为0时的ArrayList ,比如通过 new ArrayList<>(0),ArrayList 内部的数组 elementData 会指向这个 EMPTY_EL

如何在Visual Studio中调试.NET源码

今天偶然在看别人代码时,发现在他的代码里使用了Any判断List<T>是否为空。 我一般的做法是先判断是否为null,再判断Count。 看了一下Count的源码如下: 1 [__DynamicallyInvokable]2 public int Count3 {4 [__DynamicallyInvokable]5 get