Python - __all__ 变量

Python
556
0
0
2022-11-22
标签   Python基础

import *

  • 当我们向文件导入某个模块时,导入的是该模块中那些名称不以下划线(单下划线 或者双下划线 __ )开头的变量、函数和类

_

  • 因此,如果不想模块文件中的某个对象被引入到其它文件中使用,可以在其名称前添加下划线
  • 下面就来讲下 import * 的栗子

demo.py

def say():
    print("人生苦短,我学Python!")

def disPython():
    print("小菠萝教程:https://www.cnblogs.com/poloyy/")

test.py

from demo import *

say()
disPython()

执行结果

人生苦短,我学Python!
小菠萝教程:https://www.cnblogs.com/poloyy/

如果对象不想被引入呢

如果 demo.py 模块中的 disPython() 函数不想让其它文件引入,则只需将其名称改为 _disPython() 或者 __disPython()

再次执行 test.py,输出结果

人生苦短,我学Python!
Traceback (most recent call last):
  File "C:/Users/polo/Desktop/2.py", line 4, in <module>
    disPython()
NameError: name 'disPython' is not defined

test.py 文件中无法使用未引入的 disPython() 函数

Python 模块 __all__ 变量

  • 模块提供的 __all__ 变量,该变量的值是一个列表,存储的是当前模块中一些对象成员(变量、函数或者类)的名称(字符串格式)
  • 通过在模块文件中设置 __all__ 变量,当其它文件以 的形式导入该模块时,该文件中只能使用 __all__ 列表中指定的对象成员,未指定的成员是无法导入的

from 模块名 import *

demo.py

def say():
    print("人生苦短,我学Python!")

def disPython():
    print("小菠萝教程:https://www.cnblogs.com/poloyy/") 

__all__ = ["say"]

__all__ 变量只包含 say()的函数名,不包含 disPython() 函数的名称

test.py

from demo import *

say()
disPython()

运行 test.py

人生苦短,我学Python!
Traceback (most recent call last):
  File "C:/Users/mengma/Desktop/2.py", line 4, in <module>
    disPython()
NameError: name 'disPython' is not defined
  • 对于 test.py 来说,demo.py 模块中的 disPython() 函数是未引入,这样调用是非法的
  • 重点:__all__ 变量仅限于在其它文件中以 的方式引入

from 模块名 import *

使用以下 2 种方式引入模块,__all__ 变量是无效的

方式一

import 模块名 的形式导入模块,通过该方式导入模块后,总可以通过模块名前缀(如果为模块指定了别名,则可以使用模快的别名作为前缀)来调用模块内的所有成员(除了以下划线开头命名的成员)

demo.py

def say():
    print("人生苦短,我学Python!")

def disPython():
    print("小菠萝教程:https://www.cnblogs.com/poloyy/") 

__all__ = ["say"]

test.py

import demo

demo.say()
demo.disPython()

运行 test.py

人生苦短,我学Python!
小菠萝教程:https://www.cnblogs.com/poloyy/

虽然 demo.py 模块中设置有 __all__ 变量,但是当以 import demo 的方式引入后,__all__ 变量将不起作用

方式二

from 模块名 import 对象成员 的形式直接导入指定成员,使用此方式导入的模块,__all__ 变量即便设置,也不起作用

demo.py

仍然是上面的 demo 代码

test.py

from demo import say
from demo import disPython

say()
disPython()

运行 test.py