為什麼Python沒有main函數?
眾所周知,Python中沒有所謂的main函數,但是網上經常有文章提到“ Python的main函數”和“建議編寫main函數”。
其實,可能他們是想模仿真正的main函數,但是許多人都被誤導(或誤解),然後編寫了非常笨拙的代碼。
在本文中,我們來討論一下為什麼Python沒有main函數。
在開始討論之前,我們先來回答以下兩個問題:
所謂的“main函數”究竟是什麼意思?
為什麼有些編程語言必須編寫main函數?
一些編程語言將main函數作為程序的執行入口,比如C/C++、C#、Java、Go、Rust等等,這個函數具有特定的含義:
main函數名是必須的,這意味着必須有一個主函數。
最多隻能有一個main函數,這意味着程序的入口是唯一的。
語法格式有特定要求,書寫形式也相對固定。
這些語言都是編譯語言,需要將代碼編譯成可執行的二進制文件。為了讓操作系統/引導程序找到程序的開頭,需要定義這樣一個函數。
簡而言之,需要在大量可執行的代碼中定義一個至關重要的的開頭。
不難看出,對於這些語言來説,main函數是不可或缺的組成部分。
但是,當我們把目光轉向Python時,就會發現情況大不相同。
Python是一種解釋語言,即腳本語言。運行過程是從上到下,逐行進行的,這意味着它的起點是已知的。
每個.py文件都是一個可執行文件,可作為整個程序的入口文件,意味着該程序的入口很靈活,而且無需遵循任何約定。
有時運行Python項目時不需要有指定入口文件(命令行比較常見,例如“ python -m http.server 8000”),可能是因為該項目中有main.py文件,在軟件包中作為“文件”來執行。
總而言之,Python作為腳本語言不同於編譯語言。無論是單個模塊(即.py文件),還是由多個模塊組成的軟件包,Python都可以選擇一種靈活的執行方法,這完全不像其他語言那樣必須定義入口。
換句話説,Python不需要規定程序員必須在語法上定義一個統一的入口(無論是函數、類還是其他東西)。
有些學生可能會感到困惑,因為他們經常看到或編寫以下代碼:
# main file
def main:
……
if __name__ == '__main__':
main
這不就是Python的main函數嗎?相信很多人都這麼認為!
不,並不是。
除了函數名是“main”之外,這段代碼與我們前面介紹的main函數沒有半點關係,這個函數既不是必須的,也不能確定程序的執行順序。即便沒有上面這樣的main函數,也不會有任何的語法問題。
人們想編寫一個main函數的主要原因其實是為了強調這是一個主函數,希望人為地將其設置成第一個執行的函數。
他們可能認為這個名字的函數更容易記住。
他們之所以要編寫__name__ =='__main__',可能是因為想表明main只在直接執行當前腳本時才運行,而在將其導入到其他模塊時不要運行。
但是,我個人不推薦這種寫法。
舉一個簡單的例子,假設只有幾十行代碼,或者一個腳本文件實現了一個簡單的功能(一個爬蟲,或畫一隻烏龜,等等),但都是按照前面的方式編寫的。
不推薦if __name__ == '__main__'的寫法,因為:
首先,如果只有一個文件的話,那麼這個文件不可能被導出。
其次,如果有多個文件,強烈建議不要將這個語句寫在入口文件(main.py)中。從理論上講,它的內容不應該導出供其他模塊使用,因為它是起點。
最後,在多個文件的情況下,也不建議在非入口的文件中寫入這條語句,因為這條語句能做的最多也就是編寫一些測試代碼。即便如此,測試代碼也應分開寫到專用目錄或文件中。
每次看到這些笨拙的代碼時,我都會感到不適。為什麼要寫這樣的if語句?你壓根不應該將這段代碼包裝成一個函數!
總結打破慣性思維,編寫真實的代碼。main函數是某些語言的唯一入口,但不應在Python中使用。你應該瞭解腳本語言的特徵,並學習簡單而優雅的風格。
你可以使用main.py,而不是編寫main函數。由於Python程序的執行單元是腳本文件,而不是函數或類,因此建議將入口文件命名為main.py,並根據需要決定內部的函數。
將main.py作為入口文件。該文件可直接與命令行的“-m”參數結合使用。