gpt4 book ai didi

python多处理池,让一个 worker 执行不同的功能

转载 作者:太空宇宙 更新时间:2023-11-04 05:15:59 25 4
gpt4 key购买 nike

我必须对文件的每一行执行一些处理,并且输入目录中存在许多文件。我必须将处理每一行(来自多个输入文件)得到的响应转储到单个结果文件中。

我已经决定了这个流程——将所有输入文件转储到一个队列中并 fork 3-4 个工作人员,其中每个工作人员处理一个唯一的文件,读取其内容,并在处理后将响应转储到写入队列中。它们将是一个单独的进程,它将读取该队列并将结果写入输出文件。

我想出了这个代码-

def write_to_csv(queue):
file_path = os.path.join(os.getcwd(), 'test_dir', "writer.csv")
ofile = open(file_path, "w")
job_writer = csv.writer(ofile, delimiter='\a')
while 1:
line = queue.get()
if line == 'kill':
print("Kill Signal received")
break
if line:job_writer.writerow([str(line).strip()])
ofile.close()

def worker_main(file_queue, writer_queue):
print os.getpid(),"working"
while not file_queue.empty():
file_name = file_queue.get(True)
# somewhere in process_file writer_queue.put(line_resp) is called
# for every line in file_name
process_file(file_name, writer_queue)


if __name__ == "__main__":
file_queue = multiprocessing.Queue()
output_queue = multiprocessing.Queue()

writer_pool = multiprocessing.Pool(1, write_to_csv, (output_queue,))

cwd = os.getcwd()
test_dir = 'test_dir'
file_list = os.listdir(os.path.join(cwd, test_dir))
for file_name in file_list:
file_queue.put(file_name)

reader_pool = multiprocessing.Pool(3, worker_main, (file_queue, output_queue))
reader_pool.close()
reader_pool.join()

output_queue.put("kill")

print("Finished execution")

代码运行良好。但是我想知道是否可以通过单个多处理池来做同样的事情,而不是在上面的代码中使用 reader_poolwriter_pool

最佳答案

你可以通过 apply_async 做到这一点,也不要在创建 Pool 对象时设置 initializer (write_to_csvworker_main ),或者它默认情况下会运行该任务。

file_queue = multiprocessing.Queue()
output_queue = multiprocessing.Queue()

cwd = os.getcwd()
test_dir = 'test_dir'
file_list = os.listdir(os.path.join(cwd, test_dir))
for file_name in file_list:
file_queue.put(file_name)

pool = Pool(4)

pool.apply_async(write_to_csv, (output_queue,))
[pool.apply_async(worker_main, (file_queue, output_queue, )) for i in range(3)]

pool.close()
pool.join()

关于python多处理池,让一个 worker 执行不同的功能,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41695445/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com