这样做做什么,为什么应该包括:if
语句?
if __name__ == "__main__":
print("Hello, World!")
如果你试图结束一个问题 如果你想要结束一个问题 在那里有人应该应该 使用这个学说,而不是,是不是, 考虑关闭作为 重复的为什么Python在我进口时 运行我的模块? 我该如何阻止它?。而对于某些问题,如果有人只是没有调用任何函数,或者错误地期望指定函数main
自动用作切入点,使用当我启动 Python 脚本时, 主函数为何不运行? 脚本从哪里开始运行 ?.
所有答案都大致解释了它的功能。但我将举一个例子来说明它的用法,这可能有助于进一步澄清这个概念。
假设你有两个Python文件,A.py和B.py。a.py
进口进口进口b.py
。我们运行a.py
文件, 在哪里import b.py
代码先执行。在其余a.py
代码运行,文件中的代码b.py
必须完全运行。
在b.py 代码中,有一些代码是那个文件的独有代码b.py
我们不想要任何其他文件(不包括b.py
已导入 b. py 文件来运行 。
这就是这行代码检查。如果它是主文件(即,b.py
运行代码,在这种情况下它不是代码 (a.py
是正在运行的主文件),然后只有代码才能被执行。
如果 Python 口译员正在运行一个特定模块,那么__name__
全局变量将拥有值"__main__"
:
def a():
print("a")
def b():
print("b")
if __name__ == "__main__":
print ("you can see me")
a()
else:
print ("You can't see me")
b()
当您运行此脚本时, 它会打印 :
you can see me
a
如果您导入此文件, 请说A
要到文件的文件B
,然后执行文件B
时当时if __name__ == "__main__"
文件中的文件A
成为假假,所以它指纹:
You can't see me
b
您可以查看特殊变量__name__
使用此简单示例 :
创建创建文件1. py
if __name__ == "__main__":
print("file1 is being run directly")
else:
print("file1 is being imported")
创建 *file2。平平
import file1 as f1
print("__name__ from file1: {}".format(f1.__name__))
print("__name__ from file2: {}".format(__name__))
if __name__ == "__main__":
print("file2 is being run directly")
else:
print("file2 is being imported")
执行文件2. py
Output:
file1 is being imported
__name__ from file1: file1
__name__ from file2: __main__
file2 is being run directly
原因 原因 原因
if __name__ == "__main__":
main()
主要是为了避免导入锁定可能产生的问题引起的问题直接导入代码. 你想要main()
如果您的文件被直接引用( 即__name__ == "__main__"
如果您的代码是导入的, 则进口者必须从真正的主模块输入您的代码, 以避免进口锁出现问题 。
一个副作用是,您自动签署一个支持多个切入点的方法。您可以使用main()
作为切入点,但你没有 不得不时段setup.py
预计预计预计预计main()
,其他工具使用其他切入点。例如,将文件作为gunicorn
进程,您定义app()
函数代替main()
。 和setup.py
, gunicorn
输入密码时不要做任何事情(因为进口锁问题)。
当我们的模块中有某些语句时(M.py
)我们想要当它作为主(而非导入)运行时被执行, 我们可以将这些语句( 测试案例、 打印语句) 置于此下if
区块。
默认值( 当模块作为主模式运行时, 不导入)__name__
变量设置为"__main__"
,当它将进口__name__
变量将获得不同的值, 最有可能是模块的名称('M'
这有助于将模块的不同变量合并运行,并区分其具体的输入和输出语句,以及如果有任何测试案例的话。
简简,使用此“if __name__ == "main"
防止模块导入时运行(确定)代码的块。