為什麼 Python 程式碼要寫得美觀而明確

2019-12-27 09:17:00

歡迎閱讀“Python 光明節(Pythonukkah)”系列文章,這個系列文章將會討論《Python 之禪》。我們首先來看《Python 之禪》裡的前兩個原則:美觀與明確。

早在 1999 年,Python 的貢獻者之一,Tim Peters 就提出了《Python 之禪》,直到二十年後的今天,《Python 之禪》中的 19 條原則仍然對整個社群都產生著深遠的影響。為此,就像慶典光明的光明節Hanukkah一樣,我們舉行了這一次的“Python 光明節Pythonukkah”。首先,我們會討論《Python 之禪》中的前兩個原則:美觀和明確。

“Hanukkah is the Festival of Lights,

Instead of one day of presents, we get eight crazy nights.”

—亞當·桑德勒,光明節之歌

美觀勝於醜陋Beautiful is better than ugly

著名的《計算機程式的構造和解釋Structure and Interpretation of Computer Programs》中有這麼一句話:程式碼是寫給人看的,只是恰好能讓機器執行。Programs must be written for people to read and only incidentally for machines to execute.機器並不在乎程式碼的美觀性,但人類在乎。

閱讀美觀的程式碼對人們來說是一種享受,這就要求在整套程式碼中保持一致的風格。使用諸如 Blackflake8Pylint 這一類工具能夠有效地接近這一個目標。

但實際上,只有人類自己才知道什麼才是真正的美觀。因此,程式碼審查和協同開發是其中的不二法門,同時,在開發過程中傾聽別人的意見也是必不可少的。

最後,個人的主觀能動性也很重要,否則一切工具和流程都會變得毫無意義。只有意識到美觀的重要性,才能主動編寫出美觀的程式碼。

這就是為什麼美觀在眾多原則當中排到了首位,它讓“美”成為了 Python 社群的一種價值。如果有人要問,”我們真的在乎美嗎?“社群會以程式碼給出肯定的答案。

明確勝於隱晦Explicit is better than implicit

人類會歡慶光明、懼怕黑暗,那是因為光能夠讓我們看到難以看清的事物。同樣地,儘管有些時候我們會不自覺地把程式碼寫得含糊不清,但明確地編寫程式碼確實能夠讓我們理解很多抽象的概念。

“為什麼類方法中要將 self 顯式指定為第一個引數?”

這個問題已經是老生常談了,但網路上很多流傳已久的回答都是不準確的。在編寫元類metaclass時,顯式指定 self 引數就顯得毫無意義。如果你沒有編寫過元類,希望你可以嘗試一下,這是很多 Python 程式設計師的必經之路。

顯式指定 self 引數的原因並不是 Python 的設計者不想將這樣的元類視為“預設”元類,而是因為第一個引數必須是顯式的。

即使 Python 中確實允許非顯式的情況存在(例如上下文變數),但我們還是應該提出疑問:某個東西是不是有存在的必要呢?如果非顯式地傳遞引數會不會出現問題呢?有些時候,由於種種原因,這是會有問題的。總之,在寫程式碼時一旦能夠優先考慮到明確性,至少意味著能對不明確的地方提出疑問並對結果作出有效的估計。