import mutiprocessing 报错:AttributeError: module 'multiprocessing' has no attribute 'Process'

在学习多进程时:

import mutiprocessing 报错 :AttributeError: module 'multiprocessing' has no attribute 'Process'

源码如下:

# -*- coding: utf-8 -*-

import multiprocessing as mp
import threading as td

def job(a,b):
    print('aaaaaaaaaaaaaaaaaaaa')

if __name__ == '__main__':
    p1 = mp.Process(target=job,args=(1,2))
    p1.start()
    p1.join()

 

1、最开始以为 multprocessing 拼写错误,求助字典发现英语拼写无误。


2、接着判断 multiprocessing 模块没有安装,后查询发现该模块为自带的。


3、后来检查得知我源代码的名称也是 multiprocessing.py,判断有可能循环导入了自己的这段代码。
修改名称之后发现程序能够正常运行了。

下图:我的工程源码名称也是:multiprocessing.py

import mutiprocessing 报错:AttributeError: module 'multiprocessing' has no attribute 'Process'_第1张图片

python库中的 multiprocessing 模块

import mutiprocessing 报错:AttributeError: module 'multiprocessing' has no attribute 'Process'_第2张图片

修改自己的工程名称为: multiprocessing_1.py, 问题解决!!!

import mutiprocessing 报错:AttributeError: module 'multiprocessing' has no attribute 'Process'_第3张图片

 

从上面的分析得出,Python的模块导入中遵循一定的顺序,本地的模块如果跟内置模块重名,优先导入本地模块。
查询文档详细解释如下:

 当import一个模块后,python会按照下面的顺序来找那个将要导入的模块文件


1、程序的主目录。上一讲中,在codes这个目录中运行交互模式,这时候的主目录就是codes,当在那个交互模式中运行import mmmm的时候,就首先在codes这个目录中搜索相应的文件(找到.py之后编译成为.pyc)。当然,后面在网页编程中,看官会看到,所谓主目录是可以通过顶层文件设置的目录。


2、PYTHONPATH目录。这是一个环境变量设置,如果没有设置则滤去。如何进行环境变量设置,请看官google啦。


3、标准库目录。已经随着Python的安装进入到计算机中的那个。


4、任何.pth文件的内容。如果有这类文件,最后要在这类文件中搜索一下。这是一个简单的方法,在.pth文件中,加入有效目录,使之成为搜索路径。

 

 

 

 

 

你可能感兴趣的:(python)