它是一个string元素组成的list变量,定义了当你使用 from <module> import * 导入某个模块的时候能导出的符号(这里代表变量,函数,类等)。
举个栗子,下面的代码在 foo.py 中,明确的导出了符号 bar , baz
__all__ = [‘bar‘, ‘baz‘] waz = 5 bar = 10 def baz(): return ‘baz
导入实现如下:
from foo import * print bar print baz # 下面的代码就会抛出异常,因为 "waz"并没有从模块中导出,因为 __all__ 没有定义 print waz
如果把 foo.py 中 __all__ 给注释掉,那么上面的代码执行起来就不会有问题, import * 默认的行为是从给定的命名空间导出所有的符号(当然下划线开头的私有变量除外)。
需要注意的是 __all__ 只影响到了 from <module> import * 这种导入方式,对于 from <module> import <member> 导入方式并没有影响,仍然可以从外部导入。
查看更多关于Python库中常见的 __all__ 变量是干啥的的详细内容...
声明:本文来自网络,不代表【好得很程序员自学网】立场,转载请注明出处:http://www.haodehen.cn/did170669