python中的一个.py文件就是一个模块,’‘
all
’’是一个特殊变量,可以在.py文件中,也可以在__init__.py文件中。
该变量的值是一个列表,存储的是当前模块中的一些成员(变量、函数或者类)的名称。通过在模块文件中设置__all__变量,当其他文件以 ‘‘from 模块名 import *’’ 的形式导入该模块时,该文件只能使用__all__列表中指定的成员。
1、在普通模块中使用时,表示一个模块中允许哪些属性可以被导入到别的模块中
如:全局变量,函数,类。如下,test1.py和main.py
test1.py
__all__=["test"]
def test():
print('----test-----')
def test1():
print('----test1----')
main.py
from test1 import *
def main():
test()
#test1()
main()
上式两个文件在同一目录下
执行 python main.py的结果如下
若main.py文件修改如下:
from test1 import *
def main():
test()
#test1()
main()
执行 python main.py 文件输出结果显示如下:
因为在test1.py中__all__变量不包含test1函数,所以在其他模块导入时报错。所以__all__变量就是为了限制或者指定能被导入到别的模块的函数,类,全局变量等。
2、在包下的__init__.py中
假设sound/effects/
init
.py中添加
all
= [“echo”, “surround”, “reverse”]
那么就会在 from sound.effects import * 时,包含上面三个模块。当__init__.py为空时,只是导入这个包,并非导入模块。
init
.py中可以执行一些初始化内容,比如:
from . import test1 导入当前目录下的test1模块
from … import test 导入上一层目录下的test模块
因为导入包时会首先执行下__init__.py这个文件