iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > Python >如何使用Python快速打开一个百万行级别的超大Excel文件
  • 896
分享到

如何使用Python快速打开一个百万行级别的超大Excel文件

2023-06-06 16:06:35 896人浏览 安东尼

Python 官方文档:入门教程 => 点击学习

摘要

小编给大家分享一下如何使用python快速打开一个百万行级别的超大excel文件,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!有同学求助说,当他试图打开一个20M左右的excel文件时,无论是使用pandas的read_e

小编给大家分享一下如何使用python快速打开一个百万行级别的超大excel文件,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!

有同学求助说,当他试图打开一个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']id100耗时0.404秒钟>>> read_xlsx(False)['Sheet']id100耗时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 991  2 90 100 95 992  3 90 100 95 993  4 90 100 95 994  5 90 100 95 99       id 语文  数学 英语 物理999995  999996 90 100 95 99999996  999997 90 100 95 99999997  999998 90 100 95 99999998  999999 90 100 95 99999999 1000000 90 100 95 99耗时81.369秒钟

结论:处理超大的Excel文件时,使用openpyxl模块的只读模式,可以快速打开并取得指定格子的数据,但不要尝试将全部数据读入到自己定义的数据结构中,这将花费漫长的时间。对此,pandas也无能为力。

看完了这篇文章,相信你对“如何使用Python快速打开一个百万行级别的超大Excel文件”有了一定的了解,如果想了解更多相关知识,欢迎关注编程网Python频道,感谢各位的阅读!

--结束END--

本文标题: 如何使用Python快速打开一个百万行级别的超大Excel文件

本文链接: https://www.lsjlt.com/news/247820.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 如何使用Python快速打开一个百万行级别的超大Excel文件
    小编给大家分享一下如何使用Python快速打开一个百万行级别的超大Excel文件,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!有同学求助说,当他试图打开一个20M左右的excel文件时,无论是使用pandas的read_e...
    99+
    2023-06-06
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作