__ name __ 方法是一个内置方法,用于获取类或模块的名称。它通常与模块或类的其他方法一起使用。
在模块中,__ name __ 属性通常表示模块的名称,但是在脚本文件中,如果该文件被直接执行,__name __ 将设置为 "__main __ "。 我们可以将代码分成两个部分:一部分只包含函数和类定义,并且可以在多个脚本中重复使用,另一部分包含代码的主要逻辑,并且只在直接执行脚本时运行。
假设现在有两个python文件main.py和module.py文件。在module.py中定义了一个函数和一个类,main.py中调用module.py中的函数和类。
如果在module.py中有一些测试代码,例如:
def my_function():
# 函数定义
print("it's a function")
class MyClass:
# 类定义
def my_method(self):
print("it's my method")
# 测试代码
print("这是测试代码")
main.py文件如下:
import module
def main():
# 调用module.py中的函数和类
module.my_function()
my_object = module.MyClass()
my_object.my_method()
if __name__ == '__main__':
main()
此时,直接运行main.py文件,输出如下:
这是测试代码
it's a function
it's my method
显然,moudle.py中的测试代码并不是我们真正想要的结果。当我们加上if __ name__ == '__main __'条件,
def my_function():
# 函数定义
print("it's a function")
class MyClass:
# 类定义
def my_method(self):
print("it's my method")
if __name__ == '__main__':
print("这是测试代码")
输出如下:
it's a function
it's my method