我们在些python脚本的时候会看到,大多数的脚本下面都会出现这一行代码,可能起初不是很理解为什么要这样做,今天来讲一下为什么要这样写?
if __name = __main:
我们应该可以看到,这事一个if条件语句,就是说只有满足这个条件的时候,下面的我们封装的函数或者类才会执行。
那为什么要写这句话呢,是因为有时候我们封装好的模块可能不只是在一个地方调用,我们可能需要在别的地方执行这个封装好的模块,而这句话的意思概括成一句话就是“Make a script both importable and executable”,即是创造一个脚本既可以直接执行,又可以被导入到别的模块中执行。
这句话,可能一开始听的还不是很懂。下面举例说明:
先写一个模块:
#module.py
def main():
print ("we are in %s"%__name__)
if __name__ == '__main__':
main()
这个函数定义了一个main函数,我们执行一下该py文件发现结果是打印出”we are in __main__“,说明我们的if语句中的内容被执行了,调用了main():
但是如果我们从另我一个模块导入该模块,并调用一次main()函数会是怎样的结果呢?
#anothermodle.py
from module import main
main()
其执行的结果是:we are in module(module是上一个脚本的名称)
但是没有显示”we are in __main__“,也就是说模块__name__ = '__main__' 下面的函数没有执行。
这样既可以让“模块”文件运行,也可以被其他模块引入,而且不会执行函数2次。这才是关键。
总结一下:
如果我们是直接执行某个.py文件的时候,该文件中那么”__name__ == '__main__'“是True,但是我们如果从另外一个.py文件通过import导入该文件的时候,这时__name__的值就是我们这个py文件的名字而不是__main__。
这个功能还有一个用处:调试代码的时候,在”if __name__ == '__main__'“中加入一些我们的调试代码,我们可以让外部模块调用的时候不执行我们的调试代码,但是如果我们想排查问题的时候,直接执行该模块文件,调试代码能够正常运行!