使用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操作MySQL的一些基本方法
Aug 16 Python
PyQt5每天必学之日历控件QCalendarWidget
Apr 19 Python
Python下使用Scrapy爬取网页内容的实例
May 21 Python
Python基于多线程实现抓取数据存入数据库的方法
Jun 22 Python
使用TensorFlow实现SVM
Sep 06 Python
python的pip安装以及使用教程
Sep 18 Python
Python数据类型之Dict字典实例详解
May 07 Python
python实现一个函数版的名片管理系统过程解析
Aug 27 Python
Python实现快速排序的方法详解
Oct 25 Python
python3 使用Opencv打开USB摄像头,配置1080P分辨率的操作
Dec 11 Python
解决python Jupyter不能导入外部包问题
Apr 15 Python
pycharm中选中一个单词替换所有重复单词的实现方法
Nov 17 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
IIS6的PHP最佳配置方法
2007/03/19 PHP
PHP学习之输出字符串(echo,print,printf,print_r和var_dump)
2011/04/17 PHP
ThinkPHP与PHPExcel冲突解决方法
2011/08/08 PHP
全新的PDO数据库操作类php版(仅适用Mysql)
2012/07/22 PHP
深入file_get_contents函数抓取内容失败的原因分析
2013/06/25 PHP
php使用mkdir创建多级目录入门例子
2014/05/10 PHP
javascript while语句和do while语句的区别分析
2007/12/08 Javascript
javascript object array方法使用详解
2012/12/03 Javascript
director.js实现前端路由使用实例
2015/02/03 Javascript
JavaScript判断变量是否为数组的方法(Array)
2016/02/24 Javascript
JS实现HTML标签转义及反转义
2020/04/14 Javascript
React-router v4 路由配置方法小结
2017/08/08 Javascript
Vue filter介绍及详细使用
2018/04/04 Javascript
create-react-app安装出错问题解决方法
2018/09/04 Javascript
vue中利用simplemde实现markdown编辑器(增加图片上传功能)
2019/04/29 Javascript
详解微信小程序实现跑马灯效果(附完整代码)
2019/04/29 Javascript
微信小程序 swiper 组件遇到的问题及解决方法
2019/05/26 Javascript
[02:25]DOTA2英雄基础教程 熊战士
2014/01/03 DOTA
破解安装Pycharm的方法
2018/10/19 Python
对python cv2批量灰度图片并保存的实例讲解
2018/11/09 Python
Python scipy的二维图像卷积运算与图像模糊处理操作示例
2019/09/06 Python
Django异步任务线程池实现原理
2019/12/17 Python
Python实现新型冠状病毒传播模型及预测代码实例
2020/02/05 Python
python生成并处理uuid的实现方式
2020/03/03 Python
详解python datetime模块
2020/08/17 Python
雅诗兰黛旗下专业男士保养领导品牌:Lab Series
2017/05/15 全球购物
美国面料纺织品商城:Fabric.com
2017/06/28 全球购物
Europcar葡萄牙:葡萄牙汽车和货车租赁
2017/10/13 全球购物
美国环保婴儿用品公司:The Honest Company
2017/11/23 全球购物
Qoo10台湾站:亚洲领先的在线市场
2018/05/15 全球购物
捷克多品牌在线时尚商店:ANSWEAR.cz
2020/10/03 全球购物
名人演讲稿范文
2013/12/28 职场文书
2014公安机关纪律作风整顿思想汇报
2014/09/13 职场文书
求职自我评价参考范文
2019/05/16 职场文书
让人瞬间清醒的句子,句句经典,字字如金
2019/07/08 职场文书
Flask搭建一个API服务器的步骤
2021/05/28 Python