python openpyxl内存不主动释放 ——关闭Excel工作簿后内存依旧(MemoryError)

在openpyxl对Excel读写操作过程中,发现内存没有马上释放,如果得多次读取大文件,内存爪机,后续代码就无法运行。

尝试:各种wb.save()或者with open等途径无法解决。

发现:因为python的回收机制,导致内存无法马上释放,于是乎就有了

import gc (garbage collector)
del wb,ws            #wb为打开的工作表
gc.collect()         #马上内存就释放了。

效果喜人:从最高的6/7GB占用可以立刻回到1/2GB

还有一个是谷歌找到了,也记录下(不过我用了没效果)——主要是不同是以只读模式打开。

with open(xlsx_filename, "rb") as f:
    in_mem_file = io.BytesIO(f.read())

wb = load_workbook(in_mem_file, read_only=True)

  

希望可以帮到遇到类似问题的小伙伴!

原文地址:https://www.cnblogs.com/vhills/p/8252477.html