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月前
|
网络协议 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访问网络视频流的技巧。
388 4
PyAV学习笔记(一):PyAV简介、安装、基础操作、python获取RTSP(海康)的各种时间戳(rtp、dts、pts)
|
2月前
|
Python
Socket学习笔记(二):python通过socket实现客户端到服务器端的图片传输
使用Python的socket库实现客户端到服务器端的图片传输,包括客户端和服务器端的代码实现,以及传输结果的展示。
155 3
Socket学习笔记(二):python通过socket实现客户端到服务器端的图片传输
|
2月前
|
JSON 数据格式 Python
Socket学习笔记(一):python通过socket实现客户端到服务器端的文件传输
本文介绍了如何使用Python的socket模块实现客户端到服务器端的文件传输,包括客户端发送文件信息和内容,服务器端接收并保存文件的完整过程。
172 1
Socket学习笔记(一):python通过socket实现客户端到服务器端的文件传输
|
2月前
|
Python
python读写操作excel日志
主要是读写操作,创建表格
65 2
|
2月前
|
算法 Python
【10月更文挑战第9天】「Mac上学Python 18」小学奥数篇4 - 分数加减法
本篇将通过 Python 和 Cangjie 双语解决简单的分数加减法问题,帮助学生理解分数的运算规则,并学会用编程解决数学计算问题。
71 1
|
2月前
|
关系型数据库 MySQL 数据库
Mysql学习笔记(四):Python与Mysql交互--实现增删改查
如何使用Python与MySQL数据库进行交互,实现增删改查等基本操作的教程。
69 1
|
2月前
|
Ubuntu Linux Python
Ubuntu学习笔记(六):ubuntu切换Anaconda和系统自带Python
本文介绍了在Ubuntu系统中切换Anaconda和系统自带Python的方法。方法1涉及编辑~/.bashrc和/etc/profile文件,更新Anaconda的路径。方法2提供了详细的步骤指导,帮助用户在Anaconda和系统自带Python之间进行切换。
107 1
|
2月前
|
存储 Python
【免费分享编程笔记】Python学习笔记(二)
【免费分享编程笔记】Python学习笔记(二)
44 0
【免费分享编程笔记】Python学习笔记(二)
|
2月前
|
索引 Python
【免费分享编程笔记】Python学习笔记(一)
【免费分享编程笔记】Python学习笔记(一)
38 0
|
14天前
|
数据采集 数据可视化 数据挖掘
利用Python自动化处理Excel数据:从基础到进阶####
本文旨在为读者提供一个全面的指南,通过Python编程语言实现Excel数据的自动化处理。无论你是初学者还是有经验的开发者,本文都将帮助你掌握Pandas和openpyxl这两个强大的库,从而提升数据处理的效率和准确性。我们将从环境设置开始,逐步深入到数据读取、清洗、分析和可视化等各个环节,最终实现一个实际的自动化项目案例。 ####