Python:__init__.py 文件的作用
标识该目录是一个python的模块包(module package)
如果你是使用python的相关IDE来进行开发,那么如果目录中存在该文件,该目录就会被识别为 module package 。
简化模块导入操作
假设我们的模块包的目录结构如下:
└── mypackage
├── subpackage_1
│ ├── test11.py
│ └── test12.py
├── subpackage_2
│ ├── test21.py
│ └── test22.py
└── subpackage_3
├── test31.py
└── test32.py
如果我们使用最直接的导入方式,将整个文件拷贝到工程目录下,然后直接导入:
from mypackage.subpackage_1 import test11
from mypackage.subpackage_1 import test12
from mypackage.subpackage_2 import test21
from mypackage.subpackage_2 import test22
from mypackage.subpackage_3 import test31
from mypackage.subpackage_3 import test32
当然这个例子里面文件比较少,如果模块比较大,目录比较深的话,可能自己都记不清该如何导入。(很有可能,哪怕只想导入一个模块都要在目录中找很久)
这种情况下,__init__.py
就很有作用了。我们先来看看该文件是如何工作的。
__init__.py
是怎么工作的?
实际上,如果目录中包含了 __init__.py
时,当用 import 导入该目录时,会执行 __init__.py
里面的代码。
└── mypackage
├── __init__.py
├── subpackage_1
│ ├── test11.py
| | |—— Class1
│ └── test12.py
├── subpackage_2
│ ├── test21.py
│ └── test22.py
└── subpackage_3
├── test31.py
└── test32.py
如果在mypackage/__init__.py
里面加一个print("You have imported mypackage")
,Import 该文件会出现
>>> import mypackage
You have imported mypackage
很显然,__init__.py
在包被导入时会被执行,所以只需要在__init__.py
文件内import 文件下的各个def
或 .py文件
即可。这样在非本文件夹下使用mypackage
的函数或类时只需 from mypackage import funC1
注:在__init__.py
文件中 import
类 或 方法时,最好要 from .test11 import One_class