解决python执行较大excel文件openpyxl慢问题

作者:Pcject 时间:2021-06-25 15:58:04 

我就废话不多说了,大家还是直接看代码吧!

talk is cheap


 from openpyxl import Workbook
 from openpyxl.utils import get_column_letter
 from openpyxl import load_workbook
 import time
 wb = load_workbook("E:/a.xlsx", read_only=True)
 sh = wb["Sheet"]
 # rowItem = {}
 # for j in range(1,2000):
 #   for i in range(1, 30):
 #     rowItem[get_column_letter(i)] = i
 #   sh.append(rowItem)
 # wb.save("E:/a.xlsx")
 t0 = time.time()
 print(sh['V500'].value)
 t1 = time.time()
 print("openpyxl所用时间:", str(t1-t0))

import xlrd
 xlsPath = "E:/a.xlsx"
 WorkBook = xlrd.open_workbook(xlsPath)
 sh = WorkBook.sheet_by_name("Sheet")

t0 = time.time()
 print(sh.cell(499,22).value)
 t1 = time.time()
 print("xlrd所用时间:", str(t1-t0))

测试结果:


22
openpyxl所用时间: 0.44217610359191895
23.0
xlrd所用时间: 0.0010063648223876953

结论

openpyxl的慢是读取慢,可以选择xlrd代替,详细测试下面继续

不直接使用xlwt+xlrd是因为xlwt仅支持2003及以下版本,最大行数限制在65536,不够用,而openpyxl大概在一百多万

主要的说完了,下面详细说了:在写工具的时候遇到的这个问题,开始是用的xlwt+xlrd,然后行数超标了,没办法换成openpyxl使用excel2007的版本,原本测试不到三万行的数据,只要三四秒,换成openpyxl以后,花了好几分钟,具体没看多少了,然后加上函数运行时间的监视器以后,才看到是读取的时候出的问题

推测原因:

推测的话,openpyxl的根据行号列号读取的时候,是从第一行第一列开始遍历,直到行号等于指定行号,列号等于指定列号,所以要读取的行号列号越多就越慢,(也可能是从第一个有数据的行或列),而xlrd则是类似与数组一样,我们要取第几个元素,直接根据下标找到内存中对应地址的元素即可,所以无论excel总量多少,速度基本都是不变的

留下的坑

xlwt写入仅支持65536行,那xlrd的读取很可能也是,也就是超过这么多的数据可能也会出错

我这里因为是读多表数据生成单表数据,生成方式大概是Na*Nb这样,所以实际读取的不会太多,但生成的很多,所以基本可以用考虑这个问题

另外,据说xlrd读取xlsx格式的偶尔会出现问题,具体没测试,暂时用还没毛病

最后,顺带上一下监控函数运行时间的装饰器吧:


import time
from functools import wraps

def fn_timer(function):
 @wraps(function)
 def function_timer(*args, **kwargs):
   t0 = time.time()
   result = function(*args, **kwargs)
   t1 = time.time()
   print ("Total time running %s: %s seconds" %
     (function.__name__, str(t1-t0))
     )
   return result
 return function_timer

使用方式的话,就是在要监控的函数定义上面加上 @fn_timer 就行了

来源:https://blog.csdn.net/J_Object/article/details/79726993

标签:python,excel,openpyxl
0
投稿

猜你喜欢

  • python爬取一组小姐姐图片实例

    2023-08-03 15:05:45
  • python自动化八大定位元素讲解

    2022-02-24 21:46:03
  • Python字典实现简单的三级菜单(实例讲解)

    2021-07-13 12:03:32
  • 基于javascript实现最简单的选项卡切换效果

    2023-08-25 00:26:23
  • 基于python实现坦克大战游戏

    2023-01-29 01:48:30
  • 结束运行python的方法

    2022-12-07 02:56:02
  • 基于Django的ModelForm组件(详解)

    2022-03-07 18:21:04
  • Python 面向对象静态方法、类方法、属性方法知识点小结

    2022-02-10 07:45:52
  • 提高asp程序访问速度的方法

    2008-10-23 16:37:00
  • Python类中的魔法方法之 __slots__原理解析

    2023-10-01 18:49:51
  • 网页设计之关于素材和言志

    2008-03-23 13:46:00
  • python上传时包含boundary时的解决方法

    2021-03-28 08:28:54
  • python使用psutil模块获取系统状态

    2021-12-13 23:36:10
  • python中黄金分割法实现方法

    2022-05-15 01:45:24
  • pycharm + django跨域无提示的解决方法

    2021-11-07 21:15:39
  • python XlsxWriter模块创建aexcel表格的实例讲解

    2023-08-30 02:20:47
  • 防盗链接ASP函数

    2011-03-07 11:02:00
  • 在Python中append以及extend返回None的例子

    2021-05-12 10:33:34
  • python中pathlib模块的基本用法与总结

    2023-12-11 15:54:17
  • 使用Python matplotlib绘制简单的柱形图、折线图和直线图

    2022-04-08 02:13:19
  • asp之家 网络编程 m.aspxhome.com