在上一篇博客中,我们讲了在模块A中 调用函数前 加上if __name__=='__main__'
可以避免当其他模块 调用模块A中的函数时,产生我们不希望出现的属于模块A的输出。
本篇就来详细讲一讲实现的原理。。
正文
每个 .py
文件都有一个变量名__name__
, 这个变量名的值会根据这个文件的用途有两个不同的值。
一、当文件作为模块被其他文件使用时,__name__
的值是这个文件的模块名[文件名]
二、当文件作为脚本(就是作为可执行文件)使用时,__name__
的值是字符串类型的'__main__'
__name__
是python的内置变量,用于表示当前模块的名字
所以if __name__ == '__main__'
拆开来看其实就是一个 if a == b
的判断语句
# 在文件text_A中
x = 10
if __name__=='__main__':
print("__name__ 得到", __name__)
print("x:", x)
# 运行的结果得到
__name__ 得到 __main__
x: 10
# 所以我们就是利用这一点,来判断是否要继续运行if判断之后的代码,如文件text_B中所示
# 在文件text_B中
from text_A import x
# 从text_A中调入变量x
def main():
print(x)
# 定义main()函数的功能,这里就是打印出x的值
if __name__ == '__main__':
main()
# 当if __name__ == '__main__':成立的时候,就进行函数main()的调用
# 运行得到结果
10
当我们在模块 text_B 中调用模块 text_A 中定义的变量x的时候,整个text_A都会执行一遍
之所以没有将text_A的输出显示在text_B上
是因为当文件text_A处于被调用的状态的时候,它的__name__
的值已经变成了模块名text_A,,而不是等于字符串"main"
# 文件text_A
x = 10
if __name__=='__main__':
print("__name__ 得到", __name__)
print("x:", x)
# 因为if判断不成立,所以后边的两条print()指令不被执行,所以自然就不会有输出
生活,从来不会亏待每一个努力向上的人。加油