Python 中的 __all__

1 __all__ 的作用

  • __all__ 是模块公开接口的一种约定, 格式如下 : __all__ = ["foo", "bar"]

  • Python 没有原生的可见性控制,其可见性的维护是靠一套需要大家自觉遵守的”约定“,比如,下划线开头的变量对外部不可见

  • 如果定义了__all__,其他文件中使用from xxx import *导入该文件时,只会导入 __all__ 列出的成员,可以其他成员都被排除在外

# test1.py
__all__ = ['func']
def func():
    pass

#test2.py
__all__ = ['func2', 'test1']
def func2():
    pass
def func22():
    pass

# test3.py
from test2 import *

>>> func2() # 正常使用
>>> test1.func() # 正常使用
>>> func22() # 不能使用

2 __all__ 的一些小知识

2.1 控制 from xxx import * 的行为

python不提倡用 from xxx import * 这种写法。如果一个模块 xxx 没有定义 __all__,执行 from spam import * 时会将 xxx 中所有非下划线开头的成员(包括该模块import的其他模块成员)都会导入当前命名空间,这样就可能弄脏当前的命名空间。显式声明了 __all__,import * 就只会导入 __all__ 列出的成员,如果 __all__ 定义有误,还会明确地抛出异常,方便检查错误

2.2 为 lint 等代码检查工具提供辅助

编写库时,经常会在 __init__.py 中暴露整个包的 API,而这些 API 的实现可能是在包的其他模块中。如果仅仅这样写:from xxx import a, b,一些代码检查工具,如 pyflakes 会报错,认为变量 a和 b import 了但没被使用。一个可行的方法是把这个警告压掉:from xxx import a, b # noqa (No Q/A,即无质量保证),但更好的方法是显式定义 __all__,这样代码检查工具就会理解,从而不再报 unused variables 的警告

3 __all__ 的注意事项

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
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、付费专栏及课程。

余额充值