python中if __name__ == “__main__“到底有什么作用?

以下转载自https://www.jb51.net/article/51892.htm

有句话经典的概括了这段代码的意义:

“Make a script both importable and executable”意思就是说让你写的脚本模块既可以导入到别的模块中用,另外该模块自己也可执行

这句话,可能一开始听的还不是很懂。下面举例说明:

先写一个模块:

#module.py

def main():

  print "we are in %s"%__name__

if __name__ == '__main__':

  main()


但是如果我们从另我一个模块导入该模块,并调用一次main()函数会是怎样的结果呢?这个函数定义了一个main函数,我们执行一下该py文件发现结果是打印出”we are in __main__“,说明我们的if语句中的内容被执行了,调用了main():

#anothermodle.py
from module import main
main()

其执行的结果是:we are in module

但是没有显示”we are in __main__“,也就是说模块__name__ = '__main__' 下面的函数没有执行。

这样既可以让“模块”文件运行,也可以被其他模块引入,而且不会执行函数2次。这才是关键。

总结一下:

如果我们是直接执行某个.py文件的时候,该文件中那么”__name__ == '__main__'“是True,但是我们如果从另外一个.py文件通过import导入该文件的时候,这时__name__的值就是我们这个py文件的名字而不是__main__。

这个功能还有一个用处:调试代码的时候,在”if __name__ == '__main__'“中加入一些我们的调试代码,我们可以让外部模块调用的时候不执行我们的调试代码,但是如果我们想排查问题的时候,直接执行该模块文件,调试代码能够正常运行!

以下内容转载自 https://blog.csdn.net/weixin_44489066/article/details/87090928

Python没有像Java、C、C++那样定义程序的执行入口,在python中,程序是从上到下逐行编译的。Python解释器从文件的第一行开始执行程序中的def和class语句创建函数和类对象,这些对象由代码和原数据组成,且这些代码和数据在显示调用之前不会运行。

首先我们来看一下__name__,__name__是python文件的一个特殊属性,名称两边的双下划线称为dunders,是特殊方法的意思。python中每个模块都有一个名称,模块的名称可以在模块的程序语句中找到。python的每个模块可以作为库导入其他函数也可以单纯作为脚本运行,我们先通过一个示例了解两者的区别。
 

if __name__ == '__main__':
    print ('This program is being run by itself')
else:
    print ('I am being imported from another module')

这是两种运行方式下的结果:

$ python my_script.py
This program is being run by ifself
$ python
>>> import my_script
I am being imported from another module
>>>

第一种是作为一个脚本运行,第二种是作为一个库运行,通过这个结果我们知道,当程序单独作为脚本运行时其name属性是"__main__",而作为库时name属性是库的名字。

所以说__name__ == "__main__"将程序定义功能和执行功能分开,理想情况下,从命令行调用时,几乎每个Python模块都可以执行相应操作。在许多情况下,如果特定文件定义仅在系统的其他组件中使用或者作为测试执行脚本时,则可以使用__name__ == "__main__"隔离代码块来区别脚本的不同功能属性。
 

你可能感兴趣的:(Python)