Python中if __name__ == __main__作用解析
|
当你打开一个.py文件时,经常会在代码的最下面看到if __name__ == '__main__':,现在就来介 绍一下它的作用. 模块是对象,并且所有的模块都有一个内置属性 __name__。一个模块的 __name__ 的值取决于您如何应用模块。如果 import 一个模块,那么模块__name__ 的值通常为模块文件名,不带路径或者文件扩展名。但是您也可以像一个标准的程序样直接运行模块,在这 种情况下,__name__ 的值将是一个特别缺省"__main__"。 /////////////////////////////////////////////////////////////////////////////////////////////////// 在cmd 中直接运行.py文件,则__name__的值是'__main__'; 而在import 一个.py文件后,__name__的值就不是'__main__'了; 从而用if __name__ == '__main__'来判断是否是在直接运行该.py文件 如: class Test: def __init(self):pass def f(self):print 'Hello,World!' if __name__ == '__main__': Test().f() #End 你在cmd中输入: Hello,World!
你再在cmd中输入: >>>import Test >>>Test.__name__ #Test模块的__name__ 'Test' >>>__name__ #当前程序的__name__ '__main__' 无论怎样,Test.py中的"__name__ == '__main__'"都不会成立的! 所以,下一行代码永远不会运行到! (编辑:安卓应用网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- Python中用post、get方式提交数据的方法示例
- python如何通过实例方法名字调用方法
- Python简单实现TCP包发送十六进制数据的方法
- Python提升网站性能 20 倍功能实例
- python – 使用scrapy刮掉没有javascript代码的文本
- Python:将Unicode-Hex-String转换为Unicode
- Python数据分析之如何利用pandas查询数据示例代码
- 运行Python代码时,Cmd和Git bash有不同的结果
- python – 在pandas数据帧上同时操作groupby和resample?
- python – pickle的`persistent_id`的替代品?
