Python中__all__的作用

用__all__=[“fun1”, “fun2”,]来暴露接口(模块级别),一些不以下划线开头的变量(比如从其他地方 import 到当前模块的成员)可以同样被排除出去。

不提倡用 from xxx import * 的写法的,但有时候图个方便这样用。如果一个模块 spam 没有定义 all,这种写法会将 spam 中非下划线开头的成员都导入当前命名空间中,这样当然就有可能弄脏当前命名空间。如果显式声明了 all,import * 就只会导入 all 列出的成员。如果 all 定义有误,列出的成员不存在,还会明确地抛出异常,而不是默默忽略。

使用注意:
all 应该是 list 类型的
不应该动态生成 all,比如使用列表解析式。_即
all 应该写在所有 import 语句下面,和函数、常量等模块成员定义的上面。

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、付费专栏及课程。

余额充值