作为小白,经常在.py文件中看到类似这么一段不长的代码:
if __name__ == '__main__':
tryTimes = 5
print()
result = run_function()
if result:
print(result[0])
if result[1]:
print('-' * 100)
print(f'重复获取次数:{result[1]}')
else:
print(f'{tryTimes}次尝试获取失败,请检查网络以及参数')
这段代码什么意思?
简单来说.py文件被直接被执行时,if _name_ == '_main_'之下的代码块将被运行。
但是当.py文件是以模块形式被导入时,if _name_ == '_main_'下的代码块不被运行。
为什么会这样呢?这就涉及到编程语言的基础内容
函数都需要一个入口开始。
C,C++都需要有一个main函数作为程序的入口,也就是程序的运行会从main函数开始。
Java,C#必须要有一个包含Main方法的主类,作为程序入口。
Python则不相同,因为属于脚本语言,不像编译型语言那样先将程序编译成二进制再运行,而是动态的逐行解释运行。也就是从脚本第一行开始运行,没有统一的入口。
一个Python源码文件(.py)既可被直接运行,还可作为模块(也就是库),被其他.py文件导入。两种情况下.py文件的最顶层代码都会被运行(Python用缩进来区分代码层次),而当一个.py文件作为模块被导入时,我们可能不希望一部分代码被运行。
__name__是全局变量,存放的是当前模块的名字。在任何文件中,都会有如下代码:
# A文件
print(__name__)
>> __main__
但是,当A.py文件被作为模块导入到B.py文件中时,A.py文件中的 _name__的值不再_main,而是模块名,但是在B.py文件下直接print还是得到_main.
# B文件
import A.py
# 运行B文件
>> A
__main__是顶层代码执行作用域的名字。
编写私有化部分 ,这句代码以上的部分,可以被其它的调用,以下的部分只有这个文件自己可以看见,如果文件被调用了,其他人是无法看见私有化部分的。
通过_name__的值,我们可以判断出该模块是作为脚本正在执行还是被其他模块导入,而根据这个判断,我们就可以选择性地执行代码。将只有模块作为脚本执行时的代码放入到 if _name == '_main_'条件中,才能被执行。
而当模块被其他模块通过import等语句导入时,Python解释器会首先检查模块注册表sys.modules中是否有该模块,如果有,则直接利用存在的模块对象的名字空间中的变量;如果没有,创建一个空的模块对象,将其添加到*sys.modules中,在以该模块名为名的名字空间下执行该模块,除了if name == ‘main’: 条件中的代码,而被执行代码中定义的变量在该名字空间下都是可访问的。
.
.
.
2018-12-18 22:11:03写于滨州学院