Python中的__all__

文章作者:Tyan
博客:noahsnail.com  |  CSDN  |  简书

1. 动机

今天看MXNet的gluon源码时发现mxnet.gluon.data.vision__all__如下:

__all__ = ['MNIST', 'FashionMNIST', 'CIFAR10', 'CIFAR100',
           'ImageRecordDataset', 'ImageFolderDataset']

2. 作用

__all__是一个字符串list,用来定义模块中对于from XXX import *时要对外导出的符号,即要暴露的借口,但它只对import *起作用,对from XXX import XXX不起作用。

3. 测试

all.py文件时要导出的模块,内容如下:

__all__ = ['x', 'y', 'test']

x = 2
y = 3
z = 4

def test():
    print('test')
  • 测试文件一
from foo import *
print('x: ', x)

print('y: ', y)
print('z: ', z)

test()
  • 运行结果:
x:  2
y:  3
Traceback (most recent call last):
  File "test.py", line 6, in <module>
    print('z: ', z)
NameError: name 'z' is not defined
  • 测试文件二
from foo import *
from foo import z
print('x: ', x)

print('y: ', y)
print('z: ', z)

test()
  • 运行结果
x:  2
y:  3
z:  4
test

参考资料

  1. https://stackoverflow.com/questions/44834/can-someone-explain-all-in-python
Python ,`__all__` 是一个特殊变量,用于指定模块哪些对象应该被导入。具体来说,`__all__` 是一个列表,包含了当前模块所有公开的对象的名称,也就是说这些对象可以被其他模块通过 `from module import *` 的方式导入。 如果在一个模块没有定义 `__all__`,那么默认情况下,所有以单下划线 `_` 开头的对象都不会被导入。而如果定义了 `__all__`,那么只有在 `__all__` 列出的对象才会被导入。另外,如果 `__all__` 列出的对象不存在,或者是以单下划线 `_` 开头的对象,则会导致 `ImportError` 异常。 下面是一个简单的示例,演示了如何使用 `__all__` 来控制模块对象的导入: ```python # demo.py def func1(): pass def func2(): pass def _func3(): pass __all__ = ['func1', 'func2'] # main.py from demo import * func1() # 正常运行 func2() # 正常运行 _func3() # NameError: name '_func3' is not defined ``` 在上面的示例,`demo.py` 定义了三个函数,其 `_func3()` 是以单下划线 `_` 开头的,表示这个函数是模块内部使用的,不应该被其他模块导入。`__all__` 变量定义了模块公开的对象名称,只有 `func1` 和 `func2` 在其,因此只有这两个函数可以被其他模块导入。在 `main.py` ,使用 `from demo import *` 的方式导入了模块的所有公开对象,可以看到 `_func3()` 无法被访问,因为它不在 `__all__`
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值