Python实现读取大量Excel文件并跨文件批量计算平均值
作者:疯狂学习GIS 时间:2023-10-21 06:53:12
本文介绍基于Python语言,实现对多个不同Excel文件进行数据读取与平均值计算的方法。
首先,让我们来看一下具体需求:目前有一个文件夹,其中存放了大量Excel文件;文件名称是每一位同学的名字,即文件名称没有任何规律。
而每一个文件都是一位同学对全班除了自己之外的其他同学的各项打分,我们以其中一个Excel文件为例来看:
可以看到,全班同学人数(即表格行数)很多、需要打分的项目(即表格列数)有11
个(不算总分);同时,由于不能给自己打分,导致每一份表格中会有一行没有数据。
而我们需要做的,就是求出每一位同学的、11
个打分项目分别的平均分,并存放在一个新的、表头(行头与列头)与大家打分文件一致的总文件中,如下图。其中,每一个格子都代表了这位同学、这一项打分项目在经过班级除其之外的每一位同学打分后计算出的平均值。
可以看到,一个人就需要算11
次平均,更何况一个班会有数十位同学。如果单独用Excel计算,是非常麻烦的。
而借助Python,就会简单很多。具体代码如下。在这里,就不再像平日里机器学习、深度学习代码博客那样,对代码加以逐段、分部分的具体解释了,直接列出全部代码,大家参考注释即可理解。
# -*- coding: utf-8 -*-
"""
Created on Thu Apr 8 16:24:41 2021
@author: fkxxgis
"""
import os
import numpy as np
from openpyxl import load_workbook
file_path='F:/班长/2020-2021综合测评与评奖评优/01_综合测评/地信XXXX班互评打分表/' #这里是每一位同学打分Excel文件存放的路径
output_path='F:/班长/2020-2021综合测评与评奖评优/01_综合测评/地信XXXX班综合素质测评互评打分表.xlsx' #这里是最终结果存放路径,请不要和上述路径一致
first_row=5 #第一个分数所在的行数
first_column=3 #第一个分数所在的列数
all_row=32 #班级同学总数
all_column=11 #需要计算的分数项目个数
all_excel=os.listdir(file_path) #获取打分文件路径下全部Excel文件
file_row=first_row+all_row-1
file_column=first_column+all_column-1
all_mean_score=np.zeros((file_row,file_column),dtype=float) #新建一个二维数组,存放每一位同学、每一项项目的分数平均值
for now_row in range(first_row,file_row+1):
for now_column in range (first_column,file_column+1):
all_score=[]
for excel_num in range(0,len(all_excel)):
now_excel=load_workbook(file_path+all_excel[excel_num]) #打开第一个打分Excel文件
all_sheet=now_excel.get_sheet_names() #获取打分文件的全部Sheet名称
now_sheet=now_excel.get_sheet_by_name(all_sheet[0]) #本文中分数全部存储于第一个Sheet,因此下标为0
single_score=now_sheet.cell(now_row,now_column).value #获取对应单元格数据
if single_score==None: #如果这个单元格为空(也就是自己不给自己打分的那一行)
pass
else:
all_score.append(single_score)
all_mean_score[now_row-1,now_column-1]=np.mean(all_score) #计算全部同学为这一位同学、这一个打分项目所打分数的平均值
output_excel=load_workbook(output_path) #读取结果存放Excel
output_all_sheet=output_excel.get_sheet_names() #这里代码含义同上
output_sheet=output_excel.get_sheet_by_name(output_all_sheet[0])
output_sheet=output_excel.active
for output_now_row in range(first_row,file_row+1):
for output_now_column in range (first_column,file_column+1):
exec("output_sheet.cell(output_now_row,output_now_column).value=all_mean_score[output_now_row-1,output_now_column-1]") #将二维数组中每一位同学、每一项打分项目的最终平均分数写入结果文件的对应位置
output_excel.save(output_path)
至此,大功告成。
来源:https://www.cnblogs.com/fkxxgis/p/17084253.html
标签:Python,Excel,平均值
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
[MySQL binlog]mysql如何彻底解析Mixed日志格式的binlog
2024-01-16 23:34:05
Mysql简易索引方案讲解
2024-01-20 15:08:11
![](https://img.aspxhome.com/file/2023/7/67587_0s.png)
利用SQL Server复制技术实现数据同步更新
2009-10-23 14:11:00
如何创建支持FILESTREAM的数据库示例探讨
2024-01-26 15:30:13
详解MySQL存储过程参数有三种类型(in、out、inout)
2024-01-25 17:45:12
最新anaconda安装配置教程
2021-07-17 05:05:34
![](https://img.aspxhome.com/file/2023/9/82929_0s.jpg)
Python从MySQL数据库中面抽取试题,生成试卷
2024-01-18 01:40:51
![](https://img.aspxhome.com/file/2023/9/120339_0s.png)
Mac包管理器Homebrew的安装方法
2023-02-16 06:20:19
![](https://img.aspxhome.com/file/2023/2/131922_0s.png)
Vue 2.0+Vue-router构建一个简单的单页应用(附源码)
2024-05-10 14:17:43
![](https://img.aspxhome.com/file/2023/0/126460_0s.png)
java连接Access数据库的方法
2024-01-14 13:41:17
![](https://img.aspxhome.com/file/2023/6/66056_0s.png)
python编写计算器功能
2022-10-29 14:07:33
![](https://img.aspxhome.com/file/2023/1/87951_0s.jpg)
python通过wxPython打开一个音频文件并播放的方法
2021-10-20 16:15:08
Python操作PDF实现制作数据报告
2022-05-09 21:41:51
![](https://img.aspxhome.com/file/2023/9/121069_0s.png)
SQL 特殊语句(学习笔记)
2024-01-13 16:24:40
Vue Element使用icon图标教程详解(第三方)
2023-07-02 16:28:43
![](https://img.aspxhome.com/file/2023/2/139672_0s.jpg)
python爬虫超时的处理的实例
2023-02-07 15:19:11
总结分析python数据化运营关联规则
2021-06-07 22:22:05
![](https://img.aspxhome.com/file/2023/1/135221_0s.png)
Android应用开发中Action bar编写的入门教程
2022-01-03 02:25:18
FastApi如何快速构建一个web项目的实现
2022-06-29 07:24:10
![](https://img.aspxhome.com/file/2023/6/128556_0s.png)
iOS开发runloop运行循环机制学习
2024-01-24 19:03:04