有句話經典的概括了這段代碼的意義:“Make a script both importable and executable”意思就是說讓你寫的腳本模塊既可以導入到別的模塊中用,另外該模塊自己也可執行。這句話,可能一開始聽的還不是很懂。下麵舉例說明:先寫一個模塊:?12345#module.pyde...
有句話經典的概括了這段代碼的意義:
“Make a script both importable and executable”
意思就是說讓你寫的腳本模塊既可以導入到別的模塊中用,另外該模塊自己也可執行。
這句話,可能一開始聽的還不是很懂。下麵舉例說明:
先寫一個模塊:
?1 2 3 4 5 |
#module.py
def main():
print "we are in %s" % __name__
if __name__ = = '__main__' :
main()
|
這個函數定義了一個main函數,我們執行一下該py文件發現結果是列印出”we are in __main__“,說明我們的if語句中的內容被執行了,調用了main():
但是如果我們從另我一個模塊導入該模塊,並調用一次main()函數會是怎樣的結果呢?
?1 2 3 |
#anothermodle.py
from module import main
main()
|
其執行的結果是:we are in module
但是沒有顯示”we are in __main__“,也就是說模塊__name__ = '__main__' 下麵的函數沒有執行。
這樣既可以讓“模塊”文件運行,也可以被其他模塊引入,而且不會執行函數2次。這才是關鍵。
總結一下:
如果我們是直接執行某個.py文件的時候,該文件中那麼”__name__ == '__main__'“是True,但是我們如果從另外一個.py文件通過import導入該文件的時候,這時__name__的值就是我們這個py文件的名字而不是__main__。
這個功能還有一個用處:調試代碼的時候,在”if __name__ == '__main__'“中加入一些我們的調試代碼,我們可以讓外部模塊調用的時候不執行我們的調試代碼,但是如果我們想排查問題的時候,直接執行該模塊文件,調試代碼能夠正常運行!