當前位置: 妍妍網 > 碼農

Python操作的5個壞習慣,你中了幾個呢?

2024-03-31碼農

來自:Python專欄

很多文章都有介紹怎麽寫好 Python,我今天呢相反,說說寫程式碼時的幾個壞習慣。有的習慣會讓 Bug 變得隱蔽難以追蹤,當然,也有的並沒有錯誤,只是個人覺得不夠完美。

註意:範例程式碼在 Python 3.6 環境下編寫

1、用列表作函式的預設參數

看下面這個例子

正常我們期望的結果應該是這樣的

但當我們執行程式碼後,只會得到這樣的結果

與預期不一致。為什麽呢?因為 Python 列表是可變物件,而且函式傳參又是傳的參照,所以當第二次呼叫 func 方法前,b 中已經有了元素 1,呼叫後 b 最終有兩個元素 1 和 2。

範例中 func 方法比較簡單,當發現問題的時候簡單看下就能找到根源。但是,如果是在一個比較復雜的方法裏面,你有可能會粗心的忽略這一點,從而會碰到一些莫名其妙的問題。

所以,當我們要為函式設定預設參數的時候,不要使用可變物件。

上面的程式碼改成這樣就 OK 了

2、檔操作

很多剛接觸 Python 的夥伴做檔操作的時候很容易寫類似的程式碼

這沒有問題,不過檔資源我們沒有必要手動去維護,像關閉這樣的操作交給上下文管理器做就好。

這樣看起來不是清爽很多。

3、捕獲所有異常

就像上面一樣,有時我們為了能夠快速的完成功能,很容易不管三七二十一,就捕獲 Exception 異常。這可能會捕捉到鍵盤中斷(KeyboardInterrupt)(CTRL + C)或斷言錯誤(AsstionError)等異常。

捕獲不確定的異常,有時也會讓我們的程式出現莫名其妙的問題,我們應該避免這樣做。

準確的做法是根據上下文捕獲 ValueError 、AttributeError 、TypeError 等比較具體的異常,然後做適當的錯誤處理,比如打印日誌等。

4、忽略 Python 的 for…else 語法

開發中我們很容易碰到類似的需求,在一個列表中,確定某個特定的元素是否存在。比如,下面的程式碼便是確定列表中有沒有奇數存在

這裏,我們使用了一個標識 is_odd_exist,預設為 False。當找到奇數時,將其置為 True,然後跳出迴圈。這樣寫並沒有問題,但是我們可以換種方式

先介紹下 Python 的 for…else 語法,當 for 迴圈是正常結束時(即不是透過 break 跳出結束的),會執行 else 中的語句。

這裏,我們使用了相對於其他語言如 C、PHP 等不同的一種方式,完成了相同的功能,看起來程式碼也簡潔了不少。

5、使用鍵遍歷字典

初學 Python 的夥伴,可能容易寫出這樣的程式碼

同樣,這也是沒有問題的,但看起來並不直觀。字典遍歷的時候,其實可以直接取出鍵值資訊,像這樣

這樣的話,看起來要明了一些。

上面提到的幾點有些帶有自己一定的偏見,不要求大家都接受,選擇合理的使用就好。