使用__all__定义Python模块导入白名单
在Python编程中,我们常常需要将一个模块中的某些变量或函数导出到其他模块中使用。为了控制这种导入行为,避免随意导入造成的命名冲突和不必要的资源浪费,Python提供了__all__这个变量来定义模块导入的白名单。
__all__是一个列表,包含了一个模块中可以被导入的所有公共接口,比如变量名、函数名等等。当我们在一个模块中定义了__all__变量时,其他模块使用import语句导入该模块时,只有__all__中列出的接口才会被导入。
下面是一个示例:
# file: mymodule.py
__all__ = ['foo', 'bar']
def foo()
Python模块导入白名单:__all__的使用
Python中的__all__变量用于定义模块导入的白名单,控制哪些接口可被其他模块导入。当设置__all__后,import *只会导入列表中的成员,避免命名冲突和资源浪费。不过,__all__可被外部修改,不能完全确保模块安全。
订阅专栏 解锁全文
4869

被折叠的 条评论
为什么被折叠?



