python編碼規範

2022-03-13 09:13:26 字數 3472 閱讀 3983

pep8 python 編碼規範

一 **編排

1 縮排。4個空格的縮排(編輯器都可以完成此功能),不使用tap,更不能混合使用tap和空格。

2 每行最大長度79,換行可以使用反斜槓,最好使用圓括號。換行點要在操作符的後邊敲回車。

3 類和top-level函式定義之間空兩行;類中的方法定義之間空一行;函式內邏輯無關段落之間空一行;其他地方盡量不要再空行。

二 文件編排

1 模組內容的順序:模組說明和docstring—import—globals&constants—其他定義。其中import部分,又按標準、三方和自己編寫順序依次排放,之間空一行。

2 不要在一句import中多個庫,比如import os, sys不推薦。

3 如果採用from xx import xx引用庫,可以省略『module.』,都是可能出現命名衝突,這時就要採用import xx。

三 空格的使用

總體原則,避免不必要的空格。

1 各種右括號前不要加空格。

2 逗號、冒號、分號前不要加空格。

3 函式的左括號前不要加空格。如func(1)。

4 序列的左括號前不要加空格。如list[2]。

5 操作符左右各加乙個空格,不要為了對齊增加空格。

6 函式預設引數使用的賦值符左右省略空格。

7 不要將多句語句寫在同一行,儘管使用『;』允許。

8 if/for/while語句中,即使執行語句只有一句,也必須另起一行。

四 注釋

總體原則,錯誤的注釋不如沒有注釋。所以當一段**發生變化時,第一件事就是要修改注釋!

注釋必須使用英文,最好是完整的句子,首字母大寫,句後要有結束符,結束符後跟兩個空格,開始下一句。如果是短語,可以省略結束符。

1 塊注釋,在一段**前增加的注釋。在『#』後加一空格。段落之間以只有『#』的行間隔。比如:

# description : module config.

# # input : none

## output : none

2 行注釋,在一句**後加注釋。比如:x = x + 1 # increment x

但是這種方式盡量少使用。

3 避免無謂的注釋。

五 文件描述

1 為所有的共有模組、函式、類、方法寫docstrings;非共有的沒有必要,但是可以寫注釋(在def的下一行)。

2 如果docstring要換行,參考如下例子,詳見pep 257

"""return a foobang

optional plotz says to frobnicate the bizbaz first.

"""六 命名規範

總體原則,新編**必須按下面命名風格進行,現有庫的編碼盡量保持風格。

1 盡量單獨使用小寫字母『l』,大寫字母『o』等容易混淆的字母。

2 模組命名盡量短小,使用全部小寫的方式,可以使用下劃線。

3 包命名盡量短小,使用全部小寫的方式,不可以使用下劃線。

4 類的命名使用capwords的方式,模組內部使用的類採用_capwords的方式。

5 異常命名使用capwords+error字尾的方式。

6 全域性變數盡量只在模組內有效,類似c語言中的static。實現方法有兩種,一是__all__機制;二是字首乙個下劃線。

7 函式命名使用全部小寫的方式,可以使用下劃線。

8 常量命名使用全部大寫的方式,可以使用下劃線。

9 類的屬性(方法和變數)命名使用全部小寫的方式,可以使用下劃線。

9 類的屬性有3種作用域public、non-public和subclass api,可以理解成c++中的public、private、protected,non-public屬性前,字首一條下劃線。

11 類的屬性若與關鍵字名字衝突,字尾一下劃線,盡量不要使用縮略等其他方式。

12 為避免與子類屬性命名衝突,在類的一些屬性前,字首兩條下劃線。比如:類foo中宣告__a,訪問時,只能通過foo._foo__a,避免歧義。如果子類也叫foo,那就無能為力了。

13 類的方法第乙個引數必須是self,而靜態方法第乙個引數必須是cls。

七 編碼建議

1 編碼中考慮到其他python實現的效率等問題,比如運算子『+』在cpython(python)中效率很高,都是jython中卻非常低,所以應該採用.join()的方式。

2 盡可能使用『is』『is not』取代『==』,比如if x is not none 要優於if x。

3 使用基於類的異常,每個模組或包都有自己的異常類,此異常類繼承自exception。

4 異常中不要使用裸露的except,except後跟具體的exceptions。

5 異常中try的**盡可能少。比如:

try:

value = collection[key]

except keyerror:

return key_not_found(key)

else:

return handle_value(value)

要優於try:

# too broad!

return handle_value(collection[key])

except keyerror:

# will also catch keyerror raised by handle_value()

return key_not_found(key)

6 使用startswith() and endswith()代替切片進行序列字首或字尾的檢查。比如:

yes: if foo.startswith('bar'):優於

no: if foo[:3] == 'bar':

7 使用isinstance()比較物件的型別。比如

yes: if isinstance(obj, int): 優於

no: if type(obj) is type(1):

8 判斷序列空或不空,有如下規則

yes: if not seq:

if seq:

優於no: if len(seq)

if not len(seq)

9 字串不要以空格收尾。

10 二進位制資料判斷使用 if boolvalue的方式。

八、技巧:

python**規範檢查:在cmd裡面安裝:easy_install pep8,檢查時敲如下命令:pep8 -r  test.py根據提示資訊操作 。

九、案例(按照pep8規範編碼的**)

Python編碼規範

usr bin python 應用程式要定義main函式而不要直接寫指令碼 def main dosomething if name main main 如果是全域性變數,則需要顯式加上 global python 的注釋分為兩種的概念,一種是由 開頭的 真正的 注釋,另一種是 docstrings...

Python編碼規範

usr bin python 應用程式要定義main函式而不要直接寫指令碼 def main dosomething if name main main 如果是全域性變數,則需要顯式加上 global python 的注釋分為兩種的概念,一種是由 開頭的 真正的 注釋,另一種是 docstrings...

python編碼規範

pep8編碼標準 編寫 1,使用4個空格進行退進,不使用tab鍵,不允許tab和空格混用 2,每行最大長度79位元組,超過部分使用反斜槓折行 3,類和全域性函式定義間隔兩個空行,類內方法定義間隔乙個空行,類內方法定義間隔乙個空行,其他地方不加空行 文件編排 1.import 部分按標準,三方和自己編...