【发布时间】:2020-06-17 12:46:48
【问题描述】:
如何将多处理池中发生的打印重定向到StringIO()
我将sys.stdout 重定向到StringIO(),只要我不使用multiprocessing 库中的pool,它就可以正常工作。
这个玩具代码是一个例子:
import io
import sys
from multiprocessing import Pool
print_file = io.StringIO()
sys.stdout = print_file
def a_print_func(some_string):
print(some_string)
pool = Pool(2)
out = pool.map(a_print_func, [['test_1','test_1'],['test_2','test_2']])
a_print_func('no_pool')
print('no_pool, no_func')
fd = open('file.txt', 'w')
fd.write(print_file.getvalue())
fd.close()
file.txt 仅包含:
no_pool
no_pool, no_func
代替:
test_1
test_1
test_2
test_2
no_pool
no_pool, no_func
【问题讨论】:
-
@stovfl 我不知道到底是怎么回事。另外,使用线程锁不会取消多处理方面吗?
-
由于进程之间不共享内存,因此父进程和子进程之间不共享对象“print_file”。结果,孩子们写入 print_file 的内容不会被父母看到。
-
@AnarKi 你必须改用
multiprocessing锁。 -
如果你愿意,有办法将所有子进程指向一个文件。
标签: python python-3.x multiprocessing