使用Python快速打开一个百万行级别的超大Excel文件的方法


Posted in Python onMarch 02, 2021

知乎上有同学求助说,当他试图打开一个20M左右的excel文件时,无论是使用pandas的read_excel,还是直接使用xlrd或者openpyxl模块,速度都慢到无法忍受的程度,耗时大约1分钟左右。

真的会这样吗?第一感觉是,这位同学在使用openpyxl模块时没有设置只读模式。为便于测试,先用下面的代码生成一个一百万行数据的excel文件。

>>> from openpyxl import Workbook
>>> wb = Workbook()
>>> sh = wb.active
>>> sh.append(['id', '语文', '数学', '英语', '物理'])
>>> for i in range(1000000): # 写入100万行数据
	sh.append([i+1, 90, 100, 95, 99])

	
>>> wb.save(r'd:\bigxlsx.xlsx')
>>> import os
>>> os.path.getsize(r'd:\bigxlsx.xlsx') # 文件大小:20M字节
20230528

接下来定义了一个使用openpyxl模块打开文件的函数,分别考察关闭和开启只读模式的时间消耗。

>>> from openpyxl import load_workbook
>>> import time
>>> def read_xlsx(read_only):
	t0 = time.time()
	wb = load_workbook(r'd:\bigxlsx.xlsx', read_only=read_only)
	t1 = time.time()
	print(wb.sheetnames)
	print(sh.cell(row=1, column=1).value)
	print(sh.cell(row=100, column=3).value)
	print('耗时%0.3f秒钟'%(t1-t0))

	
>>> read_xlsx(True)
['Sheet']
id
100
耗时0.404秒钟
>>> read_xlsx(False)
['Sheet']
id
100
耗时67.817秒钟

运行测试,果然,不开启只读的话,真的需要1分多钟,而使用只读模式的话,则仅需0.4秒钟。

不过,也别高兴得太早,openpyxl模块并没有提供像pandas.read_excel()那样把全部数据读入一个数据结构的功能,只能定位到行、列或格子以后再读取数据。要想使用openpyxl模块把全部数据读入到数组或DataFrame中,需要遍历所有的行和列,这仍然是一个非常耗时的操作。

那么,pandas.read_excel()是否也支持只读模式呢?遗憾的是,read_excel()并没有类似read_only这样的参数。尽管read_excel()可以接受文件路径、文件对象、类文件对象,甚至是二进制数据,但即使将文件内容传入,read_excel()解析这100万行数据仍然需要大约80秒钟。下面的代码验证了这一点。

>>> import pandas as pd
>>> def read_excel_by_pandas():	
	with open(r'd:\bigxlsx.xlsx', 'rb') as fp:
		content = fp.read()
		t0 = time.time()
		df = pd.read_excel(content, engine='openpyxl')
		t1 = time.time()
	print(df.head())
	print(df.tail())
	print('耗时%0.3f秒钟'%(t1-t0))

	
>>> read_excel_by_pandas()
  id 语文  数学 英语 物理
0  1 90 100 95 99
1  2 90 100 95 99
2  3 90 100 95 99
3  4 90 100 95 99
4  5 90 100 95 99
       id 语文  数学 英语 物理
999995  999996 90 100 95 99
999996  999997 90 100 95 99
999997  999998 90 100 95 99
999998  999999 90 100 95 99
999999 1000000 90 100 95 99
耗时81.369秒钟

结论:处理超大的Excel文件时,使用openpyxl模块的只读模式,可以快速打开并取得指定格子的数据,但不要尝试将全部数据读入到自己定义的数据结构中,这将花费漫长的时间。对此,pandas也无能为力。

到此这篇关于使用Python快速打开一个百万行级别的超大Excel文件的方法的文章就介绍到这了,更多相关python打开excel文件内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
Python内建函数之raw_input()与input()代码解析
Oct 26 Python
python 实现在txt指定行追加文本的方法
Apr 29 Python
Python DataFrame设置/更改列表字段/元素类型的方法
Jun 09 Python
python文件拆分与重组实例
Dec 10 Python
python实现逐个读取txt字符并修改
Dec 24 Python
Python3最长回文子串算法示例
Mar 04 Python
详解Python数据分析--Pandas知识点
Mar 23 Python
pytorch 固定部分参数训练的方法
Aug 17 Python
Python range与enumerate函数区别解析
Feb 28 Python
解决tensorflow读取本地MNITS_data失败的原因
Jun 22 Python
M1芯片安装python3.9.1的实现
Feb 02 Python
Python 语言实现六大查找算法
Jun 30 Python
Autopep8的使用(python自动编排工具)
Mar 02 #Python
python 将Excel转Word的示例
Mar 02 #Python
Python字节单位转换(将字节转换为K M G T)
Mar 02 #Python
Python使用cn2an实现中文数字与阿拉伯数字的相互转换
Mar 02 #Python
jupyter notebook指定启动目录的方法
Mar 02 #Python
python实现发送邮件
Mar 02 #Python
matplotlib阶梯图的实现(step())
Mar 02 #Python
You might like
php在服务器执行exec命令失败的解决方法
2012/03/03 PHP
php解析url的三个示例
2014/01/20 PHP
ecshop实现smtp发送邮件
2015/02/03 PHP
php进程(线程)通信基础之System V共享内存简单实例分析
2019/11/09 PHP
如何在指定的地方插入html内容和文本内容
2013/12/23 Javascript
javascript实现浏览器窗口传递参数的方法
2014/09/03 Javascript
使用JS实现jQuery的addClass, removeClass, hasClass函数功能
2014/10/31 Javascript
5种处理js跨域问题方法汇总
2014/12/04 Javascript
JavaScript获取各大浏览器信息图示
2015/11/20 Javascript
jQuery插件EasyUI实现Layout框架页面中弹出窗体到最顶层效果(穿越iframe)
2016/08/05 Javascript
JavaScript中cookie工具函数封装的示例代码
2016/10/11 Javascript
Jquery Easyui表单组件Form使用详解(30)
2016/12/19 Javascript
如何获取元素的最终background-color
2017/02/06 Javascript
Linux使用Node.js建立访问静态网页的服务实例详解
2017/03/21 Javascript
Textarea输入字数限制实例(兼容iOS&安卓)
2017/07/06 Javascript
jQuery实现模糊查询的方法分析
2018/05/10 jQuery
Vue组件中prop属性使用说明实例代码详解
2018/05/31 Javascript
详解关于微信setData回调函数中的坑
2019/02/18 Javascript
vue-cli的build的文件夹下没有dev-server.js文件配置mock数据的方法
2019/04/17 Javascript
Smartour 让网页导览变得更简单(推荐)
2019/07/19 Javascript
JavaScript实现随机五位数验证码
2019/09/27 Javascript
JS数组reduce()方法原理及使用技巧解析
2020/07/14 Javascript
python控制台中实现进度条功能
2015/11/10 Python
python的pandas工具包,保存.csv文件时不要表头的实例
2018/06/14 Python
基于Numpy.convolve使用Python实现滑动平均滤波的思路详解
2019/05/16 Python
Python自动抢红包教程详解
2019/06/11 Python
python自动循环定时开关机(非重启)测试
2019/08/26 Python
Django import export实现数据库导入导出方式
2020/04/03 Python
Django在Model保存前记录日志实例
2020/05/14 Python
Django mysqlclient安装和使用详解
2020/09/17 Python
超30万乐谱下载:Musicnotes.com
2016/09/24 全球购物
.NET remoting中对象激活的两种方式
2015/06/08 面试题
教师个人读书活动总结
2014/07/08 职场文书
应聘教师求职信范文
2015/03/20 职场文书
单位证明范文
2015/06/18 职场文书
关于军训的感想
2015/08/07 职场文书