Python: __init__.py 的作用
init.py 的作用
init.py 主要是用来初始化 Python 包(packages)的,它在模块加载最开始运行。
以下目录结构为示例:
├─test
│ ├─package_1
│ │ ├─__init__.py
│ │ ├─m1.py
│ ├─package_2
│ │ ├─__init__.py
│ │ └─m2.py
│ ├─test.py
其中包含两个包 package_1,package_2
init.py 中有什么
如上目录结构,如果两个包中的__init__.py 都为空的话,默认在 test.py 中我们只能执行如下:
from package_2 import m2print(m2.m2s())
当想要执行
import package_2
print(package_2.m2.m2s())
或from package_2 import *
print(m2.m2s())
则会抛出异常
AttributeError: module ‘package_2’ has no attribute ‘m2’
这是因为在__init__.py 中并没有进行包提升
如何执行
此时以 package_2 包中的__init__.py 为例
当我们在包中提升导入权限即可:
from package_2.m2 import m2s
在 test.py 中,执行from package_2 import m2sprint(m2s())
通常我们经常还会遇到 from xxx import *
我们只需要在 init.py 中加载 all 允许全部导出的模块即可,如在 package_2 的 init.py 中加入
__all__ = ['m2']
test.py 中执行from package_2 import *
print(m2.m2s())
all 是一个列表变量,放的是你希望导入的模块的名字。
当 init.py 中定义了 all 变量时,import * 只能导入 __all__允许的模块