我看到很多文章写main函数的作用,巴拉巴拉,,,,但是没找到一篇解释关于《为什么用if name == ‘main’:》是因为爱么?是因为责任么?还是比较炫酷—装13?弄出来这东西肯定有它的价值吧,那么下面来看第一个test.py文件
# test.py
def ceshi函数1():
print("我是函数1,如果想其他模块中调用我,就不要在当前模块以 ceshi函数1() "
"这种形式调用,这样的话会重复执行,浪费计算资源")
def ceshi函数2():
print("我是函数2,如果想其他模块中调用我,就不要在当前模块以 ceshi函数2() "
"这种形式调用,这样的话会重复执行,浪费计算资源")
if __name__ == '__main__':
ceshi函数1()
ceshi函数2()
# test.py
def ceshi函数1():
print("我是函数1,如果想其他模块中调用我,就不要在当前模块以 ceshi函数1() "
"这种形式调用,这样的话会重复执行,浪费计算资源")
def ceshi函数2():
print("我是函数2,如果想其他模块中调用我,就不要在当前模块以 ceshi函数2() "
"这种形式调用,这样的话会重复执行,浪费计算资源")
ceshi函数1()
ceshi函数2()
上面两段代码执行的效果是一样的,所谓的一样就是都执行ceshi函数1(),ceshi函数2(),那么说if name == ‘main’:无用?,显然事情没这么简单。
再来看test2.py文件
#test2.py
# from test import ceshi测试1
from test import *
# import test
def un这个函数无关紧要():
print("。。。。")
if __name__ == '__main__':
ceshi函数1()
ceshi函数2()
你的本意是调用test模块中两个函数 ceshi函数1() ceshi函数2(),可结果是:test.py文件中有if name == ‘main’:这个语句的 的确是执行了一遍,这一遍就是test2.py文件中的调用,但是test.py文件中没有if name == ‘main’:这个语句的
却被执行两遍(这种无意义的动作会浪费大量计算资源),为什么?
原因很简单因为from test import *导入包的过程中,会执行test文件中ceshi函数1() ceshi函数2(),注意这可不是test2.py中调用的ceshi函数1() ceshi函数2(),这就是为什么执行两遍的原因。
原因找到了。就是if name == ‘main’:这个语句为test.py文件被导入时提供了一个壁垒,就像一道墙一样防止在导入过程执行if name == ‘main’:这个语句包裹的代码。对于test2文件来说,调用哪个函数执行它就可以了,比如下面代码:
#test2.py
# from test import ceshi测试1
from test import *
# import test
def un这个函数无关紧要():
print("。。。。")
if __name__ == '__main__':
ceshi函数1()
我并不想执行ceshi函数2()这个函数,就可以不调用。说到这里应该都明白了吧。其实这句话if name == ‘main’:就是“对于我来说,我就是我(main),对于你来说,我就是小明(test),不信你再看下面代码:
# test.py
def ceshi函数1():
print("我是函数1,如果想其他模块中调用我,就不要在当前模块以 ceshi函数1() "
"这种形式调用,这样的话会重复执行,浪费计算资源")
def ceshi函数2():
print("我是函数2,如果想其他模块中调用我,就不要在当前模块以 ceshi函数2() "
"这种形式调用,这样的话会重复执行,浪费计算资源")
if __name__ == 'test':
ceshi函数1()
ceshi函数2()
#test2.py
# from test import ceshi测试1
from test import *
# import test
def un这个函数无关紧要():
print("。。。。")
if __name__ == '__main__':
ceshi函数1()
ceshi函数2()
再来看这代码,执行test2.py文件时,from test import *导入包时,这句话if name == ‘test’:的逻辑判断是True,为啥?因为对于test2来说,自己叫main,test就叫test。