当前位置:首页 > 话题广场 > 财经专区 > 黄金

关于#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/caijing/2161828.html

上一篇

关于10克黄金手链我想说按“克”卖时代已过?“一口价”火热来袭,网友:金店套路满满

下一篇

【1.15克黄金戒指】中国黄金消费暴增近5成,年轻人悄然成为主力

关于#NAME?,你需要知道这些Excel中“NAME?”二三事

关于#NAME?,你需要知道这些Excel中“NAME?”二三事

#NAME?相关介绍,通常出现#NAME?符号的意思是出现了excel不能识别的东西,比如输入错误的公式、没有加引号的文本等等。 达到当天最大量API KEY 超过次数限制 用Excel筛选一列,这类里面出现了#NAME?...

#NAME?看这里!Excel中“NAME?”二三事

#NAME?看这里!Excel中“NAME?”二三事

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

关于#NAME?我想说避免这些VLOOKUP函数错误,主管都佩服地跪下了

关于#NAME?我想说避免这些VLOOKUP函数错误,主管都佩服地跪下了

#NAME?相关介绍,目前职场excel办公室最受欢迎的是什么?毫无疑问是VLOOKUP函数。上一篇文章中的小编已经说明了VLOOKUP函数,没有举过几个例子的朋友以后能推翻的话,会很有帮助。(大卫亚设)。 回归到今天的主...

#NAME??总结很全面速看!Excel中“NAME?”二三事

#NAME??总结很全面速看!Excel中“NAME?”二三事

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

#NAME?专题之避免这些VLOOKUP函数错误,主管都佩服地跪下了

#NAME?专题之避免这些VLOOKUP函数错误,主管都佩服地跪下了

#NAME?相关介绍,目前职场excel办公室最受欢迎的是什么?毫无疑问是VLOOKUP函数。上一篇文章中的小编已经说明了VLOOKUP函数,没有举过几个例子的朋友以后能推翻的话,会很有帮助。(大卫亚设)。 回归到今天的主...

关于#NAME?我想说浅析python 中__name__ = '__main__' 的作用!容易忽略的问题

关于#NAME?我想说浅析python 中__name__ = '__main__' 的作用!容易忽略的问题

#NAME?相关介绍,很多新手刚开始学习python的时候,经常会看到python中_ _ name _ _=\ ' _ _ _ main _ _ \ '这样的代码,可能很多新手在python中_ _; 有...

#NAME?,干货看这篇!浅析python 中__name__ = '__main__' 的作用!容易忽略的问题

#NAME?,干货看这篇!浅析python 中__name__ = '__main__' 的作用!容易忽略的问题

#NAME?相关介绍,很多新手刚开始学习python的时候,经常会看到python中_ _ name _ _=\ ' _ _ _ main _ _ \ '这样的代码,可能很多新手在python中_ _; 有...

关于#NAME?,你需要知道这些Excel出现“NAME”提示怎么办 如何解决Excel“NAME”提示

关于#NAME?,你需要知道这些Excel出现“NAME”提示怎么办 如何解决Excel“NAME”提示

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