使用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中为feedparser设置超时时间避免堵塞
Sep 28 Python
python实现自动更换ip的方法
May 05 Python
python实现根据主机名字获得所有ip地址的方法
Jun 28 Python
Python使用gensim计算文档相似性
Apr 10 Python
Python绘制的二项分布概率图示例
Aug 22 Python
python scipy求解非线性方程的方法(fsolve/root)
Nov 12 Python
详解如何从TensorFlow的mnist数据集导出手写体数字图片
Aug 05 Python
python使用配置文件过程详解
Dec 28 Python
Tensorflow矩阵运算实例(矩阵相乘,点乘,行/列累加)
Feb 05 Python
Python如何把多个PDF文件合并代码实例
Feb 13 Python
Jupyter Notebook远程登录及密码设置操作
Apr 10 Python
python3 删除所有自定义变量的操作
Apr 08 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 Notice: Undefined index 错误提示解决方法
2010/08/29 PHP
写出高质量的PHP程序
2012/02/04 PHP
php进程间通讯实例分析
2016/07/11 PHP
php实现贪吃蛇小游戏
2016/07/26 PHP
Yii框架组件的事件机制原理与用法分析
2020/04/07 PHP
用js计算页面执行时间的函数
2006/12/07 Javascript
Javascript !!的作用
2008/12/04 Javascript
!DOCTYPE声明对JavaScript的影响分析
2010/04/12 Javascript
javascript中的对象创建 实例附注释
2011/02/08 Javascript
JQuery插件开发示例代码
2013/11/06 Javascript
网页实时显示服务器时间和javscript自运行时钟
2014/06/09 Javascript
6种javascript显示当前系统时间代码
2015/12/01 Javascript
angular源码学习第一篇 setupModuleLoader方法
2016/10/20 Javascript
jquery插入兄弟节点的操作方法
2016/12/07 Javascript
jQuery实现的动态文字变化输出效果示例【附演示与demo源码下载】
2017/03/24 jQuery
js+SVG实现动态时钟效果
2018/07/14 Javascript
js实现验证码干扰(动态)
2021/02/23 Javascript
python生成随机验证码(中文验证码)示例
2014/04/03 Python
python中eval与int的区别浅析
2019/08/11 Python
python遍历文件目录、批量处理同类文件
2019/08/31 Python
OpenCV灰度化之后图片为绿色的解决
2020/12/01 Python
Python实现淘宝秒杀功能的示例代码
2021/01/19 Python
HTML5中的进度条progress元素简介及兼容性处理
2016/06/02 HTML / CSS
纽约现代艺术博物馆商店:MoMA STORE(室内家具和杂货商品)
2016/08/02 全球购物
购买限量版收藏品、珠宝和礼品:Bradford Exchange
2016/09/23 全球购物
TALLY WEiJL法国网上商店:服装、时装及配饰
2019/08/31 全球购物
校园网站的创业计划书范文
2013/12/30 职场文书
聘用意向书范本
2014/04/01 职场文书
幼儿园小班家长寄语
2014/04/02 职场文书
室内设计专业自荐信
2014/05/31 职场文书
平面设计专业求职信
2014/08/09 职场文书
庆祝教师节标语
2014/10/09 职场文书
女性健康知识讲座通知
2015/04/23 职场文书
党员转正大会主持词
2015/07/02 职场文书
解决redis sentinel 频繁主备切换的问题
2021/04/12 Redis
python自动化测试通过日志3分钟定位bug
2021/11/20 Python