Excel学习笔记(一):python读写excel,并完成计算平均成绩、成绩等级划分、每个同学分数大于70的次数、找最优成绩

简介: 这篇文章是关于如何使用Python读取Excel文件中的学生成绩数据,并进行计算平均成绩、成绩等级划分、统计分数大于70的次数以及找出最优成绩等操作的教程。

环境和所需准备

执行这个程序需要安装以下python环境
pip install openpyxl -i https://pypi.tuna.tsinghua.edu.cn/simple
pip install numpy -i https://pypi.tuna.tsinghua.edu.cn/simple

自己先写了个excel的文档,用于测试,内容如下
在这里插入图片描述
注意我标红的地方,可以结合代码看看,这里要记得和代码一致不然会报错,由于每个excel文件可以包含很多工作表,这为了标明我们需要的是哪个工作表

代码解读

def Read_Excel(Excelname,sheet):
    '''
    作用:读取excel表格
    '''
    excel = openpyxl.load_workbook(filename=Excelname, read_only=True)
    # print(excel[sheet])
    return excel[sheet]

这是定义了一个用于读取excel表格的函数,但是并不能够直接像excel一样可查看该文件,load_workbook 模块读取 excel 文件中对应的"修改"表中的数据,封装为列表并返回。

# 将该同学所有的成绩列为数组输出
def get_narry(kt,sy,qm):

    return list(np.array([kt,sy,qm]))

这步主要是为了方便后面直接调用数组(每个同学全部分数的组合体)

# 计算一个分数列的平均分数
def cal_avg(x):
    n = len(x)
    sum = 0
    for i in range(0,n):
        # print(x[i])
        sum += x[i]
    # print(sum)
    return sum/n

这一步很明显求平均分数,也很好理解

# 每位同学考试成绩>70的次数
def totle_times(x):
    n = len(x)
    i=0
    for i in range(0,n):
        if x[i]>70:
            i += 1
    return i

这一步是求每位同学考试成绩>70的次数,通过索引值来找值

整体代码

import numpy as np
import openpyxl

def Read_Excel(Excelname,sheet):
    '''
    作用:读取excel表格
    load_workbook 模块读取 excel 文件中对应的"修改"表中的数据,封装为列表并返回
    '''
    excel = openpyxl.load_workbook(filename=Excelname, read_only=True)
    # print(excel[sheet])
    return excel[sheet]

# 将该同学所有的成绩列为数组输出
def get_narry(kt,sy,qm):

    return list(np.array([kt,sy,qm]))

# 计算一个分数列的平均分数
def cal_avg(x):
    n = len(x)
    sum = 0
    for i in range(0,n):
        # print(x[i])
        sum += x[i]
    # print(sum)
    return sum/n

# 每位同学考试成绩>70的次数
def totle_times(x):
    n = len(x)
    i=0
    for i in range(0,n):
        if x[i]>70:
            i += 1
    return i

def get_Value(wb, tag):
    '''
    输入:获取相应单元格的数据
    wb为表格对象
    tag为单元格标签
    输出:对应单元格的数据
    '''
    return wb[tag].value

def get_Score(workbook):
    '''
    输入:包含学生的所有信息
    输出:学生成绩数据列表
    '''
    # 定义存储学生数据列表
    students_message = []
    # 定义储存学生分数等级的列表 A为优秀 B为良好 C为不及格
    minrow = workbook.min_row + 1
    maxrow = workbook.max_row + 1
    for i in range(minrow,maxrow):

        name = get_Value(workbook, 'B' + str(i))
        Id = get_Value(workbook,'A'+str(i))
        time = get_Value(workbook, 'F' + str(i))
        first = get_Value(workbook, 'C' + str(i))
        second = get_Value(workbook, 'D' + str(i))
        third = get_Value(workbook, 'E' + str(i))
        n = get_narry(first,second,third)
        layer = []
        for x in range(len(n)):
            if np.logical_or(n[x] < 0, n[x] > 100):
                print("the exist score")
            elif n[x] >= 70:
                layer.append('A')
            elif 50 <= n[x] < 70:
                layer.append('B')
            else:
                layer.append('C')
        avg_score = cal_avg(n)
        max_score = np.max(n)
        times = totle_times(n)
        students_message.append({
            '学号':Id,
            '姓名': name,
            '第一次成绩': first,
            '第二次成绩':second,
            '第三次成绩':third,
            '时间': time.date().strftime('%Y-%m-%d'),
            '等级划分':layer,
            '平均成绩':round(avg_score,2), # round可以将输出保留两位小数
            '最优成绩':max_score,
            '分数大于70次数':times
        })
        # print(layer)
    return students_message

if __name__ == '__main__':
    test = Read_Excel('D:/pycharm/arithmetic/1.xlsx', 'test')
    Students_messages = get_Score(test)
    for Students_message in Students_messages:
        print(Students_message)

运行结果

在这里插入图片描述
觉得有用点赞支持一下❤

目录
相关文章
|
2月前
|
Python
【10月更文挑战第10天】「Mac上学Python 19」小学奥数篇5 - 圆和矩形的面积计算
本篇将通过 Python 和 Cangjie 双语解决简单的几何问题:计算圆的面积和矩形的面积。通过这道题,学生将掌握如何使用公式解决几何问题,并学会用编程实现数学公式。
165 60
|
2月前
|
网络协议 Java Linux
PyAV学习笔记(一):PyAV简介、安装、基础操作、python获取RTSP(海康)的各种时间戳(rtp、dts、pts)
本文介绍了PyAV库,它是FFmpeg的Python绑定,提供了底层库的全部功能和控制。文章详细讲解了PyAV的安装过程,包括在Windows、Linux和ARM平台上的安装步骤,以及安装中可能遇到的错误和解决方法。此外,还解释了时间戳的概念,包括RTP、NTP、PTS和DTS,并提供了Python代码示例,展示如何获取RTSP流中的各种时间戳。最后,文章还提供了一些附录,包括Python通过NTP同步获取时间的方法和使用PyAV访问网络视频流的技巧。
294 4
PyAV学习笔记(一):PyAV简介、安装、基础操作、python获取RTSP(海康)的各种时间戳(rtp、dts、pts)
|
2月前
|
Python
Socket学习笔记(二):python通过socket实现客户端到服务器端的图片传输
使用Python的socket库实现客户端到服务器端的图片传输,包括客户端和服务器端的代码实现,以及传输结果的展示。
149 3
Socket学习笔记(二):python通过socket实现客户端到服务器端的图片传输
|
1月前
|
机器学习/深度学习 算法 编译器
Python程序到计算图一键转化,详解清华开源深度学习编译器MagPy
【10月更文挑战第26天】MagPy是一款由清华大学研发的开源深度学习编译器,可将Python程序一键转化为计算图,简化模型构建和优化过程。它支持多种深度学习框架,具备自动化、灵活性、优化性能好和易于扩展等特点,适用于模型构建、迁移、部署及教学研究。尽管MagPy具有诸多优势,但在算子支持、优化策略等方面仍面临挑战。
63 3
|
2月前
|
JSON 数据格式 Python
Socket学习笔记(一):python通过socket实现客户端到服务器端的文件传输
本文介绍了如何使用Python的socket模块实现客户端到服务器端的文件传输,包括客户端发送文件信息和内容,服务器端接收并保存文件的完整过程。
164 1
Socket学习笔记(一):python通过socket实现客户端到服务器端的文件传输
|
2月前
|
Python
python读写操作excel日志
主要是读写操作,创建表格
64 2
|
2月前
|
Python
【10月更文挑战第15天】「Mac上学Python 26」小学奥数篇12 - 图形变换与坐标计算
本篇将通过 Python 和 Cangjie 双语实现图形变换与坐标计算。这个题目帮助学生理解平面几何中的旋转、平移和对称变换,并学会用编程实现坐标变化。
66 1
|
2月前
|
机器学习/深度学习 移动开发 Python
【10月更文挑战第11天】「Mac上学Python 22」小学奥数篇8 - 排列组合计算
本篇将通过 Python 和 Cangjie 双语讲解如何计算排列与组合。这道题目旨在让学生学会使用排列组合公式解决实际问题,并加深对数学知识和编程逻辑的理解。
65 4
|
2月前
|
数据可视化 Python
【10月更文挑战第12天】「Mac上学Python 23」小学奥数篇9 - 基础概率计算
本篇将通过 Python 和 Cangjie 双语实现基础概率的计算,帮助学生学习如何解决简单的概率问题,并培养逻辑推理和编程思维。
53 1
|
2月前
|
算法 Python
【10月更文挑战第9天】「Mac上学Python 18」小学奥数篇4 - 分数加减法
本篇将通过 Python 和 Cangjie 双语解决简单的分数加减法问题,帮助学生理解分数的运算规则,并学会用编程解决数学计算问题。
69 1