使用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爬取软考试题之ip自动代理
Mar 28 Python
Python实现一个Git日志统计分析的小工具
Dec 14 Python
利用python 更新ssh 远程代码 操作远程服务器的实现代码
Feb 08 Python
Python 实现选择排序的算法步骤
Apr 22 Python
python实现从文件中读取数据并绘制成 x y 轴图形的方法
Oct 14 Python
详解Python正则表达式re模块
Mar 19 Python
详解pandas删除缺失数据(pd.dropna()方法)
Jun 25 Python
python 列表、字典和集合的添加和删除操作
Dec 16 Python
python GUI库图形界面开发之PyQt5滚动条控件QScrollBar详细使用方法与实例
Mar 06 Python
使用OpenCV实现道路车辆计数的使用方法
Jul 15 Python
利用Python pandas对Excel进行合并的方法示例
Nov 04 Python
python 如何用terminal输入参数
May 25 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
Zend Framework页面缓存实例
2014/06/25 PHP
PHP严重致命错误处理:php Fatal error: Cannot redeclare class or function
2017/02/05 PHP
jquery图片上下tab切换效果
2011/03/18 Javascript
JavaScript严格模式详解
2015/11/18 Javascript
jquery表单验证插件formValidator使用方法
2016/04/01 Javascript
详解jQuery lazyload 懒加载
2016/12/19 Javascript
JS实现改变HTML上文字颜色和内容的方法
2016/12/30 Javascript
JS得到当前时间的方法示例
2017/03/24 Javascript
Vue中的Vux配置指南
2017/12/08 Javascript
从零开始搭建webpack+react开发环境的详细步骤
2018/05/18 Javascript
angular4 获取wifi列表中文显示乱码问题的解决
2018/10/20 Javascript
详解JavaScript 新语法之Class 的私有属性与私有方法
2019/04/23 Javascript
js实现简单五子棋游戏
2020/05/28 Javascript
JavaScript的垃圾回收机制与内存管理
2020/08/06 Javascript
Django权限机制实现代码详解
2018/02/05 Python
Python实现OpenCV的安装与使用示例
2018/03/30 Python
Python解决线性代数问题之矩阵的初等变换方法
2018/12/12 Python
python实现贪吃蛇游戏
2020/03/21 Python
使用虚拟环境打包python为exe 文件的方法
2019/08/29 Python
使用Django和Postgres进行全文搜索的实例代码
2020/02/13 Python
详解vscode实现远程linux服务器上Python开发
2020/11/10 Python
英国伦敦的睡衣品牌:Asceno
2019/10/06 全球购物
面试后的感谢信范文
2014/02/01 职场文书
小学班干部竞选演讲稿
2014/04/24 职场文书
迎新晚会策划方案
2014/06/13 职场文书
金融管理专业求职信
2014/07/10 职场文书
机械工程及其自动化专业求职信
2014/08/08 职场文书
中国文明网向国旗敬礼寄语大全
2014/09/27 职场文书
教师批评与自我批评(群众路线)
2014/10/15 职场文书
市场总监岗位职责
2015/02/11 职场文书
2016新春团拜会致辞
2015/08/01 职场文书
禁毒主题班会教案
2015/08/14 职场文书
《火烧云》教学反思
2016/02/23 职场文书
教师个人教学反思
2016/02/23 职场文书
Python 快速验证代理IP是否有效的方法实现
2021/07/15 Python
MySQL 5.7常见数据类型
2021/07/15 MySQL