使用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中使用元类的教程
Apr 28 Python
Python实现文件复制删除
Apr 19 Python
Python爬虫实例爬取网站搞笑段子
Nov 08 Python
Python字典创建 遍历 添加等实用基础操作技巧
Sep 13 Python
pandas DataFrame的修改方法(值、列、索引)
Aug 02 Python
python装饰器的特性原理详解
Dec 25 Python
pytorch 常用线性函数详解
Jan 15 Python
Python编程快速上手——疯狂填词程序实现方法分析
Feb 29 Python
keras实现VGG16方式(预测一张图片)
Jul 07 Python
Django后端分离 使用element-ui文件上传方式
Jul 12 Python
python爬虫scrapy框架的梨视频案例解析
Feb 20 Python
Python合并pdf文件的工具
Jul 01 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守护进程 加linux命令nohup实现任务每秒执行一次
2011/07/04 PHP
php获取文件大小的方法
2014/02/26 PHP
整理php防注入和XSS攻击通用过滤
2015/09/13 PHP
封装的原生javascript弹出层代码
2010/09/24 Javascript
jquery无限级联下拉菜单简单实例演示
2015/11/23 Javascript
js实现精确到毫秒的倒计时效果
2016/08/05 Javascript
微信小程序之小豆瓣图书实例
2016/11/30 Javascript
为你的微信小程序体积瘦身详解
2017/05/20 Javascript
javascript变量提升和闭包理解
2018/03/12 Javascript
react router4+redux实现路由权限控制的方法
2018/05/03 Javascript
vue 循环加载数据并获取第一条记录的方法
2018/09/26 Javascript
浅谈Vue CLI 3结合Lerna进行UI框架设计
2019/04/14 Javascript
Vue指令之 v-cloak、v-text、v-html实例详解
2019/08/08 Javascript
layui table动态表头 改变表格头部 重新加载表格的方法
2019/09/21 Javascript
[01:45]绝对公平!DOTA2队长征召模式详解
2014/04/25 DOTA
[49:05]Newbee vs TNC 2018国际邀请赛小组赛BO2 第一场 8.16
2018/08/17 DOTA
Python交换变量
2008/09/06 Python
Python简单实现子网掩码转换的方法
2016/04/13 Python
Python的socket模块源码中的一些实现要点分析
2016/06/06 Python
Python简单检测文本类型的2种方法【基于文件头及cchardet库】
2016/09/18 Python
Python黑帽编程 3.4 跨越VLAN详解
2016/09/28 Python
Python 递归函数详解及实例
2016/12/27 Python
python3+mysql查询数据并通过邮件群发excel附件
2018/02/24 Python
Python使用win32 COM实现Excel的写入与保存功能示例
2018/05/03 Python
python判断一个集合是否为另一个集合的子集方法
2018/05/04 Python
python matplotlib绘图,修改坐标轴刻度为文字的实例
2018/05/25 Python
手把手教你pycharm专业版安装破解教程(linux版)
2019/09/26 Python
OpenCV哈里斯(Harris)角点检测的实现
2020/01/15 Python
TensorBoard 计算图的可视化实现
2020/02/15 Python
基于logstash实现日志文件同步elasticsearch
2020/08/06 Python
Monnier Frères美国官网:法国知名奢侈品网站
2016/11/22 全球购物
德国家用电器购物网站:Premiumshop24
2019/08/22 全球购物
什么是接口(Interface)?
2013/02/01 面试题
环保小标语
2014/06/13 职场文书
入党积极分子十八届四中全会思想汇报
2014/10/23 职场文书
2015年暑假工作总结
2015/07/13 职场文书