添加-m参数将会运行包中__main__.py的代码 。更多关于__main__.py文件的内容可参考如何将开源Python包发布到PyPI中 。
在三种情况中,__name__都具有相同的值:字符串'__main__' 。
技术细节:Python文档中具体定义了__name__何时取值为'__main__' 。
当通过标准输入 , 脚本或者交互提示中读取数据时,模块的__name__将取值为'__main__' 。(来源)
__name__与__doc__ , __package__和其他属性一起存储在模块的全局命名空间 。更多关于属性的信息可参考Python数据模型文档,特别是关于模块和包的信息,请参阅Python Import文档 。
导入模块或解释器
接下来是Python解释器执行代码的第二种方式:导入 。在开发模块或脚本时,可以使用import关键字导入他人已经构建的模块 。
在导入过程中,Python执行指定模块中定义的语句(但仅在第一次导入模块时) 。要演示导入execution_methods.py文件的结果 , 需要启动Python解释器,然后导入execution_methods.py文件:
在此代码输出中,Python解释器执行了三次print()函数调用 。前两行由于没有变量,在输出方面与在命令行上作为脚本执行时完全相同 。但是第三个输出存在差异 。
当Python解释器导入代码时 , __name__的值与要导入的模块的名称相同 。您可以通过第三行的输出了解这一点 。__name__的值为'execution_methods' , 是Python导入的.py文件 。
注意如果您在没有退出Python时再次导入模块,将不会有输出 。
注意:更多关于导入在Python中如何工作的内容请参考官方文档和Python中的绝对和相对导入 。
Main函数的最佳实践
既然您已经了解两种执行方式上的差异 , 那么掌握一些最佳实践方案还是很有用的 。它们将适用于编写作为脚本运行的代码或者在另一个模块导入的代码 。
如下是四种实践方式:
将大部分代码放入函数或类中
请记住 , Python解释器在导入模块时会执行模块中的所有代码 。有时如果想要实现用户可控的代码,会导致一些副作用,例如:
在这种情况下,想要实现用户控制触发此代码的执行,而不是让Python解释器在导入模块时执行代码 。
因此,最佳方法是将大部分代码包含在函数或类中 。这是因为当Python解释器遇到def或class关键字时,它只存储这些定义供以后使用,并且在用户通知之前不会实际执行 。
将如下代码保存在best_practices.py以证明这个想法:
在此代码中,首先从time模块中导入sleep() 。
在这个示例中,参数以秒的形式传入sleep()函数中,解释器将暂停一段时间再运行 。随后,使用print()函数打印关于代码描述的语句 。
之后,定义一个process_data()函数 , 执行如下五项操作:
在命令行中执行
当你将此文件作为脚本用命令行执行时会发生什么呢?
Python解释器将执行函数定义之外的from time import sleep和print(),之后将创建函数process_data() 。然后,脚本将退出而不做任何进一步的操作,因为脚本没有任何执行process_data()的代码 。
如下是这段脚本的执行结果:
我们在这里看到的输出是第一个print()的结果 。注意,从time导入和定义process_data()函数不产生结果 。具体来说,调用定义在process_data()内部的print()不会打印结果 。
导入模块或解释器执行
在会话(或其他模块)中导入此文件时,Python解释器将执行相同的步骤 。
Python解释器导入文件后,您可以使用已导入模块中定义的任何变量,类或函数 。为了证明这一点,我们将使用可交互的Python解释器 。启动解释器 , 然后键入import best_practices:
推荐阅读
- erp系统文件的建立,erp系统建设方案
- 转载公众号视频怎么保存,如何将公众号视频保存到手机
- Mysql索引有长度限制,mysql索引数量限制
- 凤凰系统安卓系统,安卓 凤凰系统
- 关于python函数使用教程的信息
- 微博html5版地址是什么意思,来自微博HTML5是什么
- 安卓手机可以测海拔的app,安卓测海拔的app最准
- 网吧单机射击恶魔游戏下载,网吧射击类单机游戏
- c语言函数与数组重要性 c语言数组的好处