使用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中global与nonlocal比较
Nov 21 Python
在Python中使用Mako模版库的简单教程
Apr 08 Python
在Mac OS上使用mod_wsgi连接Python与Apache服务器
Dec 24 Python
python try except 捕获所有异常的实例
Oct 18 Python
Python读写文件基础知识点
Jun 10 Python
Python适配器模式代码实现解析
Aug 02 Python
python异常触发及自定义异常类解析
Aug 06 Python
Python计算不规则图形面积算法实现解析
Nov 22 Python
利用Python脚本批量生成SQL语句
Mar 04 Python
Python 程序报错崩溃后如何倒回到崩溃的位置(推荐)
Jun 23 Python
python实现单机五子棋
Aug 28 Python
python音频处理的示例详解
Dec 23 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 多进程 解决难题
2009/06/22 PHP
PHP开发中常用的三个表单验证函数使用小结
2010/03/03 PHP
WordPress主题中添加文章列表页页码导航的PHP代码实例
2015/12/22 PHP
Javascript操纵Cookie实现购物车程序
2007/02/15 Javascript
javascript radio 联动效果
2009/03/04 Javascript
showModalDialog在谷歌浏览器下会返回Null的解决方法
2013/11/27 Javascript
javascript框架设计读书笔记之数组的扩展与修复
2014/12/02 Javascript
JavaScript的内存释放问题详解
2015/01/21 Javascript
PHP守护进程实例
2015/03/06 Javascript
jQuery实现新消息在网页标题闪烁提示
2015/06/23 Javascript
Bootstrap每天必学之折叠(Collapse)插件
2016/04/25 Javascript
浅析javascript中的Event事件
2016/12/09 Javascript
微信小程序实现锚点定位楼层跳跃的实例
2017/05/18 Javascript
js禁止Backspace键使浏览器后退的实现方法
2017/09/01 Javascript
[原创]jQuery实现合并/追加数组并去除重复项的方法
2018/04/11 jQuery
Javascript删除数组里的某个元素
2019/02/28 Javascript
详解利用nodejs对本地json文件进行增删改查
2019/09/20 NodeJs
Python中使用Queue和Condition进行线程同步的方法
2016/01/19 Python
Python数据结构与算法之图的基本实现及迭代器实例详解
2017/12/12 Python
Python通过matplotlib画双层饼图及环形图简单示例
2017/12/15 Python
Python冲顶大会 快来答题!
2018/01/17 Python
Python 字符串与数字输出方法
2018/07/16 Python
使用python获取(宜宾市地震信息)地震信息
2019/06/20 Python
解决matplotlib.pyplot在Jupyter notebook中不显示图像问题
2020/04/22 Python
windows10在visual studio2019下配置使用openCV4.3.0
2020/07/14 Python
sublime3之内网安装python插件Anaconda的流程
2020/11/10 Python
CK巴西官方网站:Calvin Klein巴西
2019/07/19 全球购物
西安夏日科技有限公司Java笔试题
2013/01/11 面试题
建筑个人求职信范文
2014/01/25 职场文书
铁路工务反思材料
2014/02/07 职场文书
进口业务员岗位职责
2014/04/06 职场文书
住宿生擅自离校检讨书
2014/09/22 职场文书
工作表扬信范文
2015/01/17 职场文书
手术室护士个人总结
2015/02/13 职场文书
2015年度个人思想工作总结
2015/04/08 职场文书
Python编程根据字典列表相同键的值进行合并
2021/10/05 Python