使用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程序抓取网页的HTML信息的一个小实例
May 02 Python
Python实现信用卡系统(支持购物、转账、存取钱)
Jun 24 Python
使用C++扩展Python的功能详解
Jan 12 Python
Python matplotlib通过plt.scatter画空心圆标记出特定的点方法
Dec 13 Python
python学生管理系统学习笔记
Mar 19 Python
10招!看骨灰级Pythoner玩转Python的方法
Apr 15 Python
Django如何开发简单的查询接口详解
May 17 Python
python程序变成软件的实操方法
Jun 24 Python
Pandas之DataFrame对象的列和索引之间的转化
Jun 25 Python
Python实现疫情通定时自动填写功能(附代码)
May 27 Python
python邮件中附加文字、html、图片、附件实现方法
Jan 04 Python
Python快速优雅的批量修改Word文档样式
May 20 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像数组一样存取和修改字符串字符
2014/03/21 PHP
PHP使用Alexa API获取网站的Alexa排名例子
2014/06/12 PHP
PHP实现生成透明背景的PNG缩略图函数分享
2014/07/08 PHP
变量在 PHP7 内部的实现(二)
2015/12/21 PHP
php上传大文件设置方法
2016/04/14 PHP
浅谈PHP5.6 与 PHP7.0 区别
2019/10/09 PHP
如何在PHP中生成随机数
2020/06/04 PHP
javascript中的prototype属性实例分析说明
2010/08/09 Javascript
原生javascript实现无间缝滚动示例
2014/01/28 Javascript
在Linux上用forever实现Node.js项目自启动
2014/07/09 Javascript
简单谈谈Javascript中类型的判断
2015/10/19 Javascript
微信小程序购物商城系统开发系列-工具篇的介绍
2016/11/21 Javascript
Bootstrap基本插件学习笔记之Alert警告框(20)
2016/12/08 Javascript
fullCalendar中文API官方文档
2017/02/07 Javascript
js数字舍入误差以及解决方法(必看篇)
2017/02/28 Javascript
JS判断两个对象内容是否相等的方法示例
2017/04/10 Javascript
vue用递归组件写树形控件的实例代码
2018/07/19 Javascript
vue与bootstrap实现简单用户信息添加删除功能
2019/02/15 Javascript
Node.js学习教程之Module模块
2019/09/03 Javascript
vue element 中的table动态渲染实现(动态表头)
2019/11/21 Javascript
vue+openlayers绘制省市边界线
2020/12/24 Vue.js
Python3实现从文件中读取指定行的方法
2015/05/22 Python
Python正则表达式实现截取成对括号的方法
2017/01/06 Python
python操作excel的包(openpyxl、xlsxwriter)
2018/06/11 Python
基于Pandas读取csv文件Error的总结
2018/06/15 Python
python字符串循环左移
2019/03/08 Python
pycharm设置当前工作目录的操作(working directory)
2020/02/14 Python
基于HTML5新特性Mutation Observer实现编辑器的撤销和回退操作
2016/01/11 HTML / CSS
局域网标准
2016/09/10 面试题
保护环境的建议书
2014/03/12 职场文书
高职教师先进事迹材料
2014/08/24 职场文书
2014年信贷员工作总结
2014/11/18 职场文书
2015年清剿火患专项行动工作总结
2015/07/27 职场文书
MATLAB 如何求取离散点的曲率最大值
2021/04/16 Python
高并发下Redis如何保持数据一致性(避免读后写)
2022/03/18 Redis
以MySQL5.7为例了解一下执行计划
2022/04/13 MySQL