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)

  

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

posted on 2018-01-09 17:12  vhills  阅读(13299)  评论(0编辑  收藏  举报