Python并行计算
程序员文章站
2022-03-07 11:29:54
...
多进程
在python
中使用multiprocessing
时,multiprocessing.Pool
必须写在if __name__ == '__main__':
下,否则会报错,不是很实用(Windows下)。在ubuntu
下可以正常使用,不需要写在main
下参考解释。
import multiprocessing
def fun(p):
print(p)
return p[0], p[1]
def do_something(x):
v = pow(x, 2)
return v
if __name__ == '__main__':
t_dir = "C:/Users/user/Desktop/u"
dir_list = os.listdir(t_dir)
lst = []
for i in range(len(dir_list)):
lst.append((dir_list[i], i))
p = multiprocessing.Pool(4)
# items = [x for x in range(1, 100000000)]
dis= p.map(fun, lst)
p.close()
p.join()