Python ThreadPoolExecutor等待的时间不足以完成任务

基本上,我需要处理(转换PDF格式,调整大小并保存)多张图像,然后将它们加载到tkinter中。这是代码的相关部分。

def part(i):
    global prog
    zoom = 5    # zoom factor
    mat = fitz.Matrix(zoom,zoom)
    page = doc.loadPage(i) #number of page
    pix = page.getpixmap(matrix = mat)
    output = "Output_Images\\Ques_"+str(i+1)+".png"
    pix.writePNG(output)
    prog += ((1/pages)*50)
    progress['value'] = prog
    load.update_idletasks()

executor = concurrent.futures.ThreadPoolExecutor(max_workers = 4)
for i in range(0,pages):
    executor.submit(part,i)

launch_main()

launch_main()函数将所有图像以及几个其他小部件放入一个循环内的tk.Text中。我面临的问题是,有时候最后几张图像(每次运行都会变化)没有插入tk.Text中。

Output_Images目录包含所有图像,这意味着launch_main()函数调用比预期的要早,因此在保存所有图像之前它的循环结束。

但是,如果我改为这样做,即添加time.sleep(),它似乎可以正常工作。

executor = concurrent.futures.ThreadPoolExecutor(max_workers = 4)
for i in range(0,i)
    time.sleep(0.1)

有没有更好的解决方案来解决这个问题?任何帮助将不胜感激。

相关文章

功能概要:(目前已实现功能)公共展示部分:1.网站首页展示...
大体上把Python中的数据类型分为如下几类: Number(数字) ...
开发之前第一步,就是构造整个的项目结构。这就好比作一幅画...
源码编译方式安装Apache首先下载Apache源码压缩包,地址为ht...
前面说完了此项目的创建及数据模型设计的过程。如果未看过,...
python中常用的写爬虫的库有urllib2、requests,对于大多数比...