作为一个菜鸟级别的我,因为导包问题还纠结了好长时间,在这附上我觉得最浅显易懂转载的一篇博客:
之前犯的错误是直接 import 同目录下的文件名,在导包是一直显示No module named XXX。按书本上是没错的,如果哪位同仁知道这个问题,请告知一下,多谢~最后用from 文件夹名 import 文件名 才成功的。
问题解决了,是因为我的pycharm编译器的问题,路径出了一些问题。具体怎么解决请参照:
问题描述:
首先文件夹的目录结构如下:
count.py文件,代码如下:
#coding=utf-8
def add(a=3,b=8):
return a+b
if __name__ == '__main__':
print add()
counttest.py文件,代码如下:
#coding=utf-8
from model import count
c=add(4,6)
print c
运行之后,显示的结果是:
理论上讲,从model导入count.py文件,是对的,到底哪里出错了?
这个主要是导包之后的函数依然需要用 文件名.函数名调用,在counttest.py文件中更改如下:c=count.add(4,6)
同时总结一下调包的三种方案。
三种解决方案:
(1)在model目录下新建__init__.py文件,内容为空。
运行结果如下:
(2)在__init__.py文件写入:
import count
在counttest.py文件更改为:
#coding=utf-8
from model import * #这一行做了更改
c=count.add(4,6)
print c
运行结果如下:
(3)在__init__文件中,更改为:
#coding=utf-8
__all__ = ['count'] #count为需要导入的文件
运行结果如下:
原理:
原来在python模块的每一个包中,都有一个__init__.py文件(这个文件定义了包的属性和方法)然后是一些模块文件和子目录,假如子目录中也有 __init__.py 那么它就是这个包的子包了。当你将一个包作为模块导入(比如从 xml导入 dom )的时候,实际上导入了它的 __init__.py 文件。
一个包是一个带有特殊文件 __init__.py 的目录。__init__.py 文件定义了包的属性和方法。其实它可以什么也不定义;可以只是一个空文件,但是必须存在。如果 __init__.py 不存在,这个目录就仅仅是一个目录,而不是一个包,它就不能被导入或者包含其它的模块和嵌套包。
_init__.py 文件:
__init__.py 控制着包的导入行为。假如 __init__.py 为空,那么仅仅导入包是什么都做不了的。
>>> import Package1
>>> Package1.Module1
Traceback (most recent call last):
File "D:/Work Space/Python practice/MyPractice/src/test.py", line 8, in <module>
aa=Package1.Module1
AttributeError: 'module' object has no attribute 'Module1'
我们需要在 __init__.py 里把 Module1 预先导入:
#文件 __init__.py
import Module1
测试:
>>> import Package1
>>> aa=Package1.Module1
>>> print aa
__init__.py 中还有一个重要的变量,叫做 __all__。我们有时会使出一招“全部导入”,也就是这样:
from PackageName import *
这时 import 就会把注册在包 __init__.py 文件中 __all__ 列表中的子模块和子包导入到当前作用域中来。比如:
#文件 __init__.py
__all__ = ["Module1", "Module2", "subPackage1", "subPackage2"]
测试:
>>> from Package1 import *
>>>
test1111111111111111111111
test222222
__init__.py 文件会在导入时被执行。