在Python程序中,你會經常看到__name__,例如:
if __name__ == '__main__': main()
本文將介紹如何正確使用和理解這個變量。
請注意,__name__在程序中是一個變量,只不過這個變量的命名有點奇怪,用雙下劃線開頭和結尾。這種命名的方法,在Pyhton的類對象設計中,常常用于一些具有特殊作用的屬性或者方法名稱[2]。
如果將編寫的一個Python文件,即.py為擴展名的文件,作為模塊被其他程序引入的時候,我們需要通過__name__這個變量,決定在引入的時候是否要運行該文件。
例如創建一個文件namescript.py,內容如下:
def my_function(): print('the value of __name__ is ' + __name__) def main(): my_function() if __name__ == "__main__": main()
如果執行namescript.py文件,其執行流程如下:
在程序中的代碼被執行之前,Python解析器先給__name__變量賦值為__main__。然后逐行執行程序中的代碼。注意,當執行到第7行的時候,判斷__name__的值是否為__main__,如果條件為真,就執行main()這個前面自定義的函數,并最終打印出結果。
如果將namescript.py文件作為一個模塊,在另外一個文件中引入,例如在名為importingscript.py的文件中,有代碼:
import namescript as nsns.my_function()
這樣,就在importingscript.py文件中使用了namescript.py文件中定義的函數my_function。如此,避免了重復代碼,而且提升了開發效率。這是Python語言的重要特點。
如果執行importscript.py文件,其流程如下圖所示:
在importscript.py中,變量__name__被賦值為__main__,然后執行import namescript,Python解析器會自動在模塊名字后面增加.py并在檢索目錄中查找該文件——所以,在引入模塊的時候不要寫成import namescript.py。找到了,就引入該文件中的所有代碼。
然后,將namescript.py文件所運行的空間中的__name__設置為namescript。結合上圖,在importingscript.py和namescript.py中,分別有兩個同名的__name__變量,但是,它們的值不同。如此,在namescript.py中,因為__name__的值是namescript了,于是該文件中的if __name__ == "__main__"條件不再成立,所以此條件下的main()函數不再執行。
在importingscript.py中,調用了namescript.my_function(),打印的結果是:the value of __name__ is namescript,這里的__name__當然是namescript.py中的變量。
如果在importingscript.py中,增加print(__name__),打印出來的結果應該是__main__。