用Python编写学生成绩计算系统

简介: 用Python编写学生成绩计算系统

举一个简单的例子,大学里面的成绩我们都知道,不是一锤定音,而是有很多成绩然后占比不同,最后才会有总评成绩,所以注重细节才是最重要的!下面我们就来看看这个吧!


项目需求:有一份CSV文件里面包含很多学生的成绩(很多平时成绩,还有姓名,学号),这个程序要做的是,利用规定好的算法和规则,把总评成绩计算出来,然后排名,打印出每个阶段的成绩信息作为教研改革。同时必须输出好看,写入TXT文件文件!


涉及知识:Python全部语法!


项目特点:格式化了打印,使得输出比较好看直观,函数结构化,帮助代码阅读,项目可移植,简单易懂


解析文件

def csv_students():
    global student_infos
    import csv
    student_infos = []
    with open(r"成绩详细.csv", encoding='utf-8-sig') as file:#将你的CSV文件和该程序文件放在一个文件夹下面
        f_csv = csv.reader(file)
        header = next(f_csv)
        for row in f_csv:
            student_info = {}
            for index in range(6):
                student_info[header[index]] = row[index]
            student_infos.append(student_info)
        # 格式化打印函数,使其输出自动对齐
        add_print1()

将其文件解析,然后以字典的形式展示,但是这里优化了代码,使得打印好看。这里我们导入的CSV这个库,对于它的一些属性操作语法,我们可以百度看看。首先


我们建立了一个列表用于后面我们存储字典所有,然后打开了这个文件,并用.reader()读取表头信息,然后将这个表头取出来,这样方便我们后续操作.next()


之后我们用循环创建字典,每个字典里面的键和值都是我们自己加上的。6各标题,6个信息,我们就完成键和值的匹配,这样就完整的创建了一个字典,最后直到我们完全读取了这些东西,循环才结束。


实现效果:


image.png

计算成绩

def scores_students():
    for scores in student_infos:
        total = float(scores["实验1"]) * 1 / 10 + float(scores["实验2"]) * 1 / 10 + \
                float(scores["实验3"]) * 2 / 10 + float(scores["期末成绩"]) * 6 / 10
        scores["总评成绩"] = total
    # 根据总评成绩进行排名,并打印出来(附加功能)
    student_infos.sort(key=lambda item: item["总评成绩"], reverse=True)
    i = 0
    for score in student_infos:
        i += 1
        score["班级排名"] = i
    add_print2()
    import json
    # 将解析后的CSV文件,转换为python对象,并储存在一个文件里面(附加功能)
    with open(r"student.txt", "w", encoding="utf_8") as file:
        json.dump(student_infos, file, ensure_ascii=False, indent=0)

image.png


image.png

分段打印:

def grad_students():
    num1 = 0
    num2 = 0
    num3 = 0
    num4 = 0
    num5 = 0
    for scores in student_infos:
        grade = float(scores["总评成绩"])
        if grade < 60:
            num1 += 1
        elif grade >= 60 and grade < 70:
            num2 += 1
        elif grade >= 70 and grade < 80:
            num3 += 1
        elif grade >= 80 and grade < 90:
            num4 += 1
        elif grade >= 90 and grade <= 100:
            num5 += 1
    all = int(num1 + num2 + num3 + num4 + num5)
    print("\t总的人数有%s人" % (all))
    # 打印出分数段人数和所占比
    print("\t[0, 60)的有 {}人 ".format(num1), "\t占比为{}".format(str(num1 / all * 100)[:4] + "%"))
    print("\t[60,70)的有{}人".format(num2), "\t占比为{}".format(str(num2 / all * 100)[:4] + "%"))
    print("\t[70,80)的有{}人".format(num3), "\t占比为{}".format(str(num3 / all * 100)[:4] + "%"))
    print("\t[80,90)的有{}人".format(num4), "\t占比为{}".format(str(num4 / all * 100)[:4] + "%"))
    print("\t[90,100]的有{}人".format(num5), "\t占比为{}".format(str(num5 / all * 100)[:4] + "%"))

image.png

查找学生

def find_students():
    while True:
        study_num = input("请输入您要查找的学号: ")
        for score in student_infos:
            if score["学号"] == study_num:
                print("姓名:", score["姓名"], "学号:", score["学号"], "实验1:",
                      score["实验1"], "实验2:", score["实验2"], "实验3:",
                      score["实验3"], "期末成绩:", score["期末成绩"], "总评成绩:",
                      score["总评成绩"], "班级排名:", score["班级排名"])
            continue

image.png


这样结束了,当然这里我们叫做后端开发项目,一般我们手机或者教务系统里面的我们叫做图形界面操作开发,这个就需要我们后面的知识了。

点击此处下载源码进行操作!!!

相关文章
|
24天前
|
机器学习/深度学习 数据可视化 搜索推荐
基于python的汽车数据可视化、推荐及预测系统
本研究围绕汽车数据可视化、推荐及预测系统展开,结合大数据与人工智能技术,旨在提升用户体验与市场竞争力。内容涵盖研究背景、意义、相关技术如 Python、ECharts、协同过滤及随机森林回归等,探讨如何挖掘汽车数据价值,实现个性化推荐与智能预测,为汽车行业智能化发展提供支持。
|
21天前
|
存储 安全 数据管理
基于python的在线考试系统
本系统基于Python开发,旨在通过信息化手段提升各行业数据管理效率。系统具备良好的安全性、稳定性及可扩展性,支持数据高效处理与决策支持,适用于教育、医疗、旅游等多个领域,助力办公自动化与科学化管理,显著提升工作效率并降低错误率。
|
13天前
|
数据采集 数据可视化 关系型数据库
基于python大数据的电影数据可视化分析系统
电影分析与可视化平台顺应电影产业数字化趋势,整合大数据处理、人工智能与Web技术,实现电影数据的采集、分析与可视化展示。平台支持票房、评分、观众行为等多维度分析,助力行业洞察与决策,同时提供互动界面,增强观众对电影文化的理解。技术上依托Python、MySQL、Flask、HTML等构建,融合数据采集与AI分析,提升电影行业的数据应用能力。
|
18天前
|
数据采集 数据可视化 安全
基于python大数据的天气可视化分析预测系统
本研究探讨基于Python的天气预报数据可视化系统,旨在提升天气数据获取、分析与展示的效率与准确性。通过网络爬虫技术快速抓取实时天气数据,并运用数据可视化技术直观呈现天气变化趋势,为公众出行、农业生产及灾害预警提供科学支持,具有重要的现实意义与应用价值。
|
21天前
|
存储 机器学习/深度学习 关系型数据库
基于python的个人财务记账系统
本研究探讨了基于Python的个人财务记账系统的设计与实现。随着经济快速发展,个人财务管理日益重要,传统手工记账方式效率低且易出错,而现有商业软件功能复杂、缺乏个性化。Python凭借其简洁语法和强大库支持,适用于开发高效、易用的记账系统。系统结合Pyecharts实现数据可视化,利用MySQL进行数据存储,具备自动分类、统计分析、财务报表生成等功能,帮助用户清晰掌握财务状况,合理规划收支,提升财务管理效率。研究具有重要的现实意义和应用前景。
|
19天前
|
存储 JavaScript 关系型数据库
基于python+vue的居家办公系统的设计与实现
本居家办公系统基于B/S架构,采用Python语言及Django框架开发,结合MySQL数据库和Vue.js前端技术,实现家具销售库存的科学化、规范化管理。系统旨在提升办公效率,降低数据错误率,优化信息管理流程,适应多行业信息化发展需求,具有良好的扩展性与实用性。
|
13天前
|
JavaScript 关系型数据库 MySQL
基于python+vue的贫困生资助系统
本文介绍了餐厅点餐系统的开发环境与核心技术,涵盖Python语言、MySQL数据库、Django框架及Vue.js前端技术,详细说明了各项技术的应用与优势,助力系统高效开发与稳定运行。
|
13天前
|
Python
基于python的餐厅点餐系统
本课题研究开发餐厅点餐系统,旨在提升餐厅信息处理效率与管理水平。通过计算机技术规范点餐流程,加快信息处理速度,助力管理人员高效运作。系统包含功能结构图与具体实现模块,全面展示系统设计与运行逻辑。
|
20天前
|
JavaScript 关系型数据库 MySQL
基于python的医院智慧门诊系统研究
本系统基于Python和Django框架,结合MySQL、Vue等技术,构建功能全面、易用性强的医院智慧门诊平台。系统涵盖患者与医务人员信息管理、在线挂号、智能导诊、电子病历、远程医疗等功能,优化就医流程,提升医疗效率与服务质量,助力医疗服务数字化转型。
基于python的医院智慧门诊系统研究
|
22天前
|
数据可视化 大数据 数据挖掘
基于python大数据的招聘数据可视化分析系统
本系统基于Python开发,整合多渠道招聘数据,利用数据分析与可视化技术,助力企业高效决策。核心功能包括数据采集、智能分析、可视化展示及权限管理,提升招聘效率与人才管理水平,推动人力资源管理数字化转型。

推荐镜像

更多