当前位置:首页 > 话题广场 > 历史专区 > 晋朝

#NAME?专题之浅析python 中__name__ = '__main__' 的作用!容易忽略的问题

很多新手刚开始学习python的时候经常会看到python 中__name__ = \'__main__\' 这样的代码,可能很多新手一开始学习的时候都比较疑惑,python 中__name__ = '__main__' 的作用,到底干嘛的? 有句话经典的概括了这段代码的意义: “Make a script both importable and executable” 意思就是说让你写的脚本模块既可以导入到别的模块中用,另外该模块自己也可执行。 达到当天最大量API KEY 超过次数限制

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

先写一个模块:

#module.py def main(): print "we are in %s"%__name__ if __name__ == '__main__': main()

这个函数定义了一个main函数,我们执行一下该py文件发现结果是打印出”we are in __main__“,说明我们的if语句中的内容被执行了,调用了main():

但是如果我们从另我一个模块导入该模块,并调用一次main()函数会是怎样的结果呢?

#ano 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__'“中加入一些我们的调试代码,我们可以让外部模块调用的时候不执行我们的调试代码,但是如果我们想排查问题的时候,直接执行该模块文件,调试代码能够正常运行!

最后多说一句,小编是一名python开发工程师,这里有我自己整理了一套最新的python系统学习教程,包括从基础的python脚本到web开发、爬虫、数据分析、数据可视化、机器学习等。想要这些资料的可以关注小编,并在后台私信小编:“01”即可领取。

1.《#NAME?专题之浅析python 中__name__ = '__main__' 的作用!容易忽略的问题》援引自互联网,旨在传递更多网络信息知识,仅代表作者本人观点,与本网站无关,侵删请联系页脚下方联系方式。

2.《#NAME?专题之浅析python 中__name__ = '__main__' 的作用!容易忽略的问题》仅供读者参考,本网站未对该内容进行证实,对其原创性、真实性、完整性、及时性不作任何保证。

3.文章转载时请保留本站内容来源地址,https://www.lu-xu.com/lishi/2064677.html

上一篇

相对于东汉东晋南宋,为什么西汉西晋北宋在现代更为人熟知

下一篇

317年晋朝的将军专题之晋朝权臣五十二岁而亡,难道是被外星人暗杀了?

【#NAME?】专题Excel出现“NAME”提示怎么办 如何解决Excel“NAME”提示

【#NAME?】专题Excel出现“NAME”提示怎么办 如何解决Excel“NAME”提示

#NAME?相关介绍,使用Excel时出现“#NAME”错误消息提示。 这通常是因为使用了公式无法识别的文本。 解决这种情况,选择“插入”→“名称”→“定义”,打开“定义名称”。如果列举的没有所需要的名称,可以在“在当前工...

#NAME?专题之Excel出现“NAME”提示怎么办 如何解决Excel“NAME”提示

#NAME?专题之Excel出现“NAME”提示怎么办 如何解决Excel“NAME”提示

#NAME?相关介绍,使用Excel时出现“#NAME”错误消息提示。 这通常是因为使用了公式无法识别的文本。 解决这种情况,选择“插入”→“名称”→“定义”,打开“定义名称”。如果列举的没有所需要的名称,可以在“在当前工...

【#NAME?】专题Excel中“NAME?”二三事

【#NAME?】专题Excel中“NAME?”二三事

#NAME?相关介绍,通常会出现#NAME吗?符号表示excel无法识别的输入错误公式、没有引号的文本等。 用Excel筛选一列,这类里面出现了#NAME?,如下 进行筛选,筛选#NAME?, 筛选的结果: 直接筛选是筛选...

#NAME?看这里!Excel中最头疼的DIV/0!N/A、NAME,到底啥原因?咋解决?

#NAME?看这里!Excel中最头疼的DIV/0!N/A、NAME,到底啥原因?咋解决?

#NAME?相关介绍,输入公式时,经常会出现错误的信息。这些错误值是因为公式无法正确计算结果,或者公式引用的单元格中存在错误。 下面介绍一下常见的错误值及其解决方法。 1 “#####!”错误值的处理方法 如果单元格所含的...

#NAME?专题之Linux操作系统中的namespace是个什么鬼

#NAME?专题之Linux操作系统中的namespace是个什么鬼

#NAME?相关介绍,第一次了解Docker后,笔者希望通过了解docker背后的技术原理来深入学习和使用docker。以下几篇文章简要介绍了Linux namespace的概念和基本用法。 namespace 的概念 n...

【#NAME?】专题VLOOKUP又失灵?避免这四种错误类型

  • 【#NAME?】专题VLOOKUP又失灵?避免这四种错误类型
  • 【#NAME?】专题VLOOKUP又失灵?避免这四种错误类型
  • 【#NAME?】专题VLOOKUP又失灵?避免这四种错误类型
#NAME?专题之Excel提示“NAME?”错误信息 Excel提示错误信息的解决方法

#NAME?专题之Excel提示“NAME?”错误信息 Excel提示错误信息的解决方法

#NAME?相关介绍,Excel提示“#NAME?”错误消息如何解决Excel提示错误消息 Excel经常显示错误的值信息,如#DIV/O。#NUM!等等,这是什么原因?那该怎么解决呢?接下来,会计网络编制介绍了在Exce...

#NAME?看这里!错误代码“NAME?”怎么解决

#NAME?看这里!错误代码“NAME?”怎么解决

#NAME?相关介绍,[计算机报纸在线]在Excel(2003/2007)中写表格时经常使用一些函数和公式,如果使用不当,将返回一些错误代码。 例如“#NAME?”,这个故障怎么解决? 情况1:在公式中使用了Excel无法...