如何限制 Python 中的并发线程数?
例如,我有一个包含许多文件的目录,我想处理所有文件,但一次只能并行处理 4 个。
这是我到目前为止所拥有的:
def process_file(fname):
# open file and do something
def process_file_thread(queue, fname):
queue.put(process_file(fname))
def process_all_files(d):
files=glob.glob(d + '/*')
q=Queue.Queue()
for fname in files:
t=threading.Thread(target=process_file_thread, args=(q, fname))
t.start()
q.join()
def main():
process_all_files('.')
# Do something after all files have been processed
如何修改代码以便一次只运行 4 个线程?
请注意,我想等待所有文件都被处理,然后继续处理已处理的文件。