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)

运行结果

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

目录
相关文章
|
4月前
|
存储 数据可视化 BI
Python可视化应用——学生成绩分布柱状图展示
本程序使用Python读取Excel中的学生成绩数据,统计各分数段人数,并通过Matplotlib库绘制柱状图展示成绩分布。同时计算最高分、最低分及平均分,实现成绩可视化分析。
288 0
|
10月前
|
存储 数据采集 数据处理
如何在Python中高效地读写大型文件?
大家好,我是V哥。上一篇介绍了Python文件读写操作,今天聊聊如何高效处理大型文件。主要方法包括:逐行读取、分块读取、内存映射(mmap)、pandas分块处理CSV、numpy处理二进制文件、itertools迭代处理及linecache逐行读取。这些方法能有效节省内存,提升效率。关注威哥爱编程,学习更多Python技巧。
254 8
|
10月前
|
存储 JSON 对象存储
如何使用 Python 进行文件读写操作?
大家好,我是V哥。本文介绍Python中文件读写操作的方法,包括文件读取、写入、追加、二进制模式、JSON、CSV和Pandas模块的使用,以及对象序列化与反序列化。通过这些方法,你可以根据不同的文件类型和需求,灵活选择合适的方式进行操作。希望对正在学习Python的小伙伴们有所帮助。欢迎关注威哥爱编程,全栈路上我们并肩前行。
232 4
|
9月前
|
机器学习/深度学习 存储 数据可视化
这份Excel+Python飞速搞定数据分析手册,简直可以让Excel飞起来
本书介绍了如何将Python与Excel结合使用,以提升数据分析和处理效率。内容涵盖Python入门、pandas库的使用、通过Python包操作Excel文件以及使用xlwings对Excel进行编程。书中详细讲解了Anaconda、Visual Studio Code和Jupyter笔记本等开发工具,并探讨了NumPy、DataFrame和Series等数据结构的应用。此外,还介绍了多个Python包(如OpenPyXL、XlsxWriter等)用于在无需安装Excel的情况下读写Excel文件,帮助用户实现自动化任务和数据处理。
|
网络协议 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访问网络视频流的技巧。
2943 4
PyAV学习笔记(一):PyAV简介、安装、基础操作、python获取RTSP(海康)的各种时间戳(rtp、dts、pts)
|
Python
Socket学习笔记(二):python通过socket实现客户端到服务器端的图片传输
使用Python的socket库实现客户端到服务器端的图片传输,包括客户端和服务器端的代码实现,以及传输结果的展示。
523 3
Socket学习笔记(二):python通过socket实现客户端到服务器端的图片传输
|
JSON 数据格式 Python
Socket学习笔记(一):python通过socket实现客户端到服务器端的文件传输
本文介绍了如何使用Python的socket模块实现客户端到服务器端的文件传输,包括客户端发送文件信息和内容,服务器端接收并保存文件的完整过程。
578 1
Socket学习笔记(一):python通过socket实现客户端到服务器端的文件传输
|
Python
python读写操作excel日志
主要是读写操作,创建表格
154 2
|
算法 Python
【10月更文挑战第9天】「Mac上学Python 18」小学奥数篇4 - 分数加减法
本篇将通过 Python 和 Cangjie 双语解决简单的分数加减法问题,帮助学生理解分数的运算规则,并学会用编程解决数学计算问题。
199 1
|
关系型数据库 MySQL 数据库
Mysql学习笔记(四):Python与Mysql交互--实现增删改查
如何使用Python与MySQL数据库进行交互,实现增删改查等基本操作的教程。
178 1