Python库的__all__变量是用来定义模块导出哪些类的?
- 内容介绍
- 文章标签
- 相关推荐
本文共计372个文字,预计阅读时间需要2分钟。
它是一个由字符串元素组成的列表变量,定义了当你使用 `from module import *` 导入某个模块时能导出的符号(这里代表变量、函数、类等)。以下是一个在 `foo.py` 文件中的例子,明确导出了以下内容:
它是一个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>导入方式并没有影响,仍然可以从外部导入。
本文共计372个文字,预计阅读时间需要2分钟。
它是一个由字符串元素组成的列表变量,定义了当你使用 `from module import *` 导入某个模块时能导出的符号(这里代表变量、函数、类等)。以下是一个在 `foo.py` 文件中的例子,明确导出了以下内容:
它是一个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>导入方式并没有影响,仍然可以从外部导入。

