在jupyter创建多进程会卡住,原因大概是由于jupyter本身就是一个进程,因此无法调用多进程。
在pycharm中创建多进程,导入该模块出现
multiprocessing是标准库,应该不需要安装第三方库来解决,但我们还是尝试安装第三方库解决一下这个问题。结果再次报错SyntaxError: Missing parentheses in call to ‘print’. Did you mean print(‘Macros:’)?
安装不成功,大概意思缺括号,网上给出答案也是。你用py2的语法玩py3,
print没有()。但我是安装模块呀,并非运行print打印函数。只好通过其他方案来运行。一种是直接用Python解释器来运行该脚本
代码为:
from multiprocessing import Pool
import os, time, random
def long_time_task(name):
print("Persent process is %s(%s)"%(name,os.getpid()))
start = time.time()
time.sleep(random.random())
end = time.time()
print('Task %s runs %0.2f seconds.' % (name, (end - start)))
if __name__=="__main__":
print('Parent process %s.' % os.getpid())
p = Pool(4)
for i in range(5):
p.apply_async(long_time_task, args=(i,))
print('Waiting for all subprocesses done...')
p.close()
p.join()
print('All subprocesses done.')
通过脚本运行.不采用pycharm中的虚拟环境:
可以看到没有问题。
另一种方式是用multiprocess代替multiprocessing。因为multiprocess模块的接口与multiprocessing基本相同;部分函数、方法的传参不完全一样,不过,但对于通常应用情景不会有差别。
程序运行没有问题了。但是这报错原因还有待进一步探究。