用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


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

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

相关文章
|
1月前
|
算法 搜索推荐 JavaScript
基于python智能推荐算法的全屋定制系统
本研究聚焦基于智能推荐算法的全屋定制平台网站设计,旨在解决消费者在个性化定制中面临的选择难题。通过整合Django、Vue、Python与MySQL等技术,构建集家装设计、材料推荐、家具搭配于一体的一站式智能服务平台,提升用户体验与行业数字化水平。
|
30天前
|
存储 分布式计算 大数据
基于Python大数据的的电商用户行为分析系统
本系统基于Django、Scrapy与Hadoop技术,构建电商用户行为分析平台。通过爬取与处理海量用户数据,实现行为追踪、偏好分析与个性化推荐,助力企业提升营销精准度与用户体验,推动电商智能化发展。
|
29天前
|
机器学习/深度学习 大数据 关系型数据库
基于python大数据的台风灾害分析及预测系统
针对台风灾害预警滞后、精度不足等问题,本研究基于Python与大数据技术,构建多源数据融合的台风预测系统。利用机器学习提升路径与强度预测准确率,结合Django框架实现动态可视化与实时预警,为防灾决策提供科学支持,显著提高应急响应效率,具有重要社会经济价值。
|
29天前
|
机器学习/深度学习 大数据 关系型数据库
基于python大数据的青少年网络使用情况分析及预测系统
本研究基于Python大数据技术,构建青少年网络行为分析系统,旨在破解现有防沉迷模式下用户画像模糊、预警滞后等难题。通过整合多平台亿级数据,运用机器学习实现精准行为预测与实时干预,推动数字治理向“数据驱动”转型,为家庭、学校及政府提供科学决策支持,助力青少年健康上网。
|
2月前
|
数据采集 数据可视化 关系型数据库
基于python大数据的电影数据可视化分析系统
电影分析与可视化平台顺应电影产业数字化趋势,整合大数据处理、人工智能与Web技术,实现电影数据的采集、分析与可视化展示。平台支持票房、评分、观众行为等多维度分析,助力行业洞察与决策,同时提供互动界面,增强观众对电影文化的理解。技术上依托Python、MySQL、Flask、HTML等构建,融合数据采集与AI分析,提升电影行业的数据应用能力。
基于python的餐厅点餐系统
本课题研究开发餐厅点餐系统,旨在提升餐厅信息处理效率与管理水平。通过计算机技术规范点餐流程,加快信息处理速度,助力管理人员高效运作。系统包含功能结构图与具体实现模块,全面展示系统设计与运行逻辑。

推荐镜像

更多