python代码格式规范

对于python而言,官方的PEP8规范是使用最广泛,认可度最高的代码规范,具体可访问:PEP 8
在线Python代码规范

1 代码布局

1.1 缩进:多行代码的缩进与对齐

我的个人习惯是用制表符(4个空格)
多行结构上的闭大括号/尖括号/圆括号可以对齐到列表最后一行的第一个非空白字符下

my_list = [
    1, 2, 3,
    4, 5, 6,
    ]
result = some_function_that_takes_arguments(
    'a', 'b', 'c',
    'd', 'e', 'f',
    )

或者:

my_list = [
    1, 2, 3,
    4, 5, 6,
]
result = some_function_that_takes_arguments(
    'a', 'b', 'c',
    'd', 'e', 'f',
)
1.2 最大的行宽:79

官方建议:限制行最大字符数为 79 。如何过长需要通过 "" 或者括号(圆括号,中括号,花括号)进行换行
使用括号进行换行,第二行第一个字符需要与括号里的第一个字符对齐

x = ('This is  a test '
     'for python style')

无法使用括号的,则通过“\" 进行换行

with open('/path/to/some/file/you/want/to/read') as file_1, \
       open('/path/to/some/file/being/written', 'w') as file_2:
    file_2.write(file_1.read())
1.3 二元操作符的连接与换行

错误的写法

# Wrong:
# operators sit far away from their operands
income = (gross_wages +
          taxable_interest +
          (dividends - qualified_dividends) -
          ira_deduction -
          student_loan_interest)

正确的写法:视线不用跨越两行,能够直观的看出对变量进行的操作

income = (gross_wages
          + taxable_interest
          + (dividends - qualified_dividends)
          - ira_deduction
          - student_loan_interest)
1.4 空行的使用
  • 模块级函数和类定义之间空两行
  • 类成员函数之间空一行
  • 可以使用多个空行分隔多组相关的函数
  • 函数中可以使用空行分隔出逻辑相关的代码
class A:

    def __init__(self):
        pass

    def hello(self):
        pass


def main():
    pass
1.5 编码

python3 默认编码 UTF-8,python2 默认编码 ASCII 。使用默认编码不需要声明
若 python2 中需要使用UTF-8编码,需要在文件头部加入 #--conding:utf-8--

1.6 import模块导入

import语句应该放在文件头部,置于模块说明及docstring之后,于全局变量之前;

  • 模块导入顺序:不同类型的模块之间最好用空行进行分割
    1.标准模块
    2.第三方模块
    3.自编模块

  • import 语句应该分行来写

# Correct:
import os
import sys

# Wrong: 也不是不能用,是不推荐
import sys, os
  • 推荐使用绝对路径导入:
# Correct:
from subprocess import Popen, PIPE复制代码
import语句应该使用 absolute import
# Correct:
from foo.bar import Bar

# Wrong
from ..bar import Bar
  • 当从包含类的模块中导入一个类时
from myclass import MyClass
from foo.bar.yourclass import YourClass
  • 如果发生命名冲突,则可使用命名空间
import bar
import foo.bar

bar.Bar()
foo.bar.Bar()
1.7 书写顺序
  • 文档说明:docstring在最前面,接着是下划线开头或者结尾的模块及变量,然后是标准模块导入等的
"""This is the example module.

This module does stuff.
"""

from __future__ import barry_as_FLUFL

__all__ = ['a', 'b', 'c']
__version__ = '0.1'
__author__ = 'Cardinal Biggles'

import os
import sys

2 字符串引号

单引号或者双引号都是可以的,根据自己的习惯。当字符串中本身包含单引号或者双引号时,可以选择另外一个,避免使用 \l来进行转义

3 表达式和语句中的空格

3.1 以下情况不需要出现空格
  • 方括号、中括号、大括号内不需要空格
# Correct:
spam(ham[1], {eggs: 2})
# Wrong:
spam( ham[ 1 ], { eggs: 2 } )
  • 末尾,和 ) 之间 不需要空格
# Correct:
foo = (0,)
# Wrong:
bar = (0, )
  • 逗号、分号、冒号前不需要空格
# Correct:
if x == 4: print x, y; x, y = y, x
# Wrong:
if x == 4 : print x , y ; x , y = y , x
  • 切片左右的空格可以被省略
# Correct:
ham[1:9], ham[1:9:3], ham[:9:3], ham[1::3], ham[1:9:]
ham[lower:upper], ham[lower:upper:], ham[lower::step]
ham[lower+offset : upper+offset]
ham[: upper_fn(x) : step_fn(x)], ham[:: step_fn(x)]
ham[lower + offset : upper + offset]
# Wrong:
ham[lower + offset:upper + offset]
ham[1: 9], ham[1 :9], ham[1:9 :3]
ham[lower : : upper]
ham[ : upper]
  • 函数调用 ( 前不需要空格
# Correct:
spam(1)
# Wrong:
spam (1)
  • 不要为了对齐而增加多余的空格
# Correct:
x = 1
y = 2
long_variable = 3
# Wrong:
x             = 1
y             = 2
long_variable = 3

*其他建议:

  • 不要存在拖尾空格
  • 反斜杠后面不要存在空格或者空行
  • 二次运算符左右两边各需要一个空格: =,+=, -= ,==, <, >, !=, <>, <=, >=, in, not in, is, is not,and, or, not
# Correct:
i = i + 1
submitted += 1
x = x*2 - 1
hypot2 = x*x + y*y
c = (a+b) * (a-b)
# Wrong:
i=i+1
submitted +=1
x = x * 2 - 1
hypot2 = x * x + y * y
c = (a + b) * (a - b)
  • 当用于指示关键字参数或用于指示未带注释的函数形参的默认值时,不要在=符号周围使用空格
# Correct:
def complex(real, imag=0.0):
    return magic(r=real, i=imag)
# Wrong:
def complex(real, imag = 0.0):
    return magic(r = real, i = imag)
  • 不建议使用复合语句
# Correct:
if foo == 'blah':
    do_blah_thing()
do_one()
do_two()
do_three()
Rather not:

# Wrong:
if foo == 'blah': do_blah_thing()
do_one(); do_two(); do_three()

# Wrong:
if foo == 'blah': do_blah_thing()
for x in lst: total += x
while t < 10: t = delay()

4 末尾逗号的使用

  • 一般末尾不需要加逗号
# Correct:
FILES = ('setup.cfg',)
# Wrong:
FILES = 'setup.cfg',
  • 多行时可以加逗号,一行时就不需要加逗号了
# Correct:
FILES = [
    'setup.cfg',
    'tox.ini',
    ]
initialize(FILES,
           error=True,
           )
# Wrong:
FILES = ['setup.cfg', 'tox.ini',]
initialize(FILES, error=True,)

5 注释

5.1 块注释 : # 号后空一格,段落件用空行分开(同样需要“#”号)
# something
# something
#
# something
# something
5.2 行注释:至少使用两个空格和语句分开,注意不要使用无意义的注释
x = x + 1                 # Compensate for border
5.3 文档注释:

作为文档的Docstring一般出现在模块头部、函数和类的头部,python中可以通过对象的doc对象获取文档.

  • 文档注释以 """ 开头和结尾, 首行不换行, 如有多行, 末行必需换行, 以下是Google的docstring风格示例
  • 不要在文档注释复制函数定义原型, 而是具体描述其具体内容, 解释具体参数和返回值等

6 命名规范

  • 不要使用 'l' , 'O', 'I'
  • 模块(或函数)的命名应该全部都是小写,多个单词之间用下划线分割即可,不过尽量简短
  • 类的命名可使用用驼峰(ClassAbc),首字母大写,私有类可用一个下划线开头
  • 函数的命名最好小写,如有多个单词,用下划线隔开
  • 变量名尽量小写, 如有多个单词,用下划线隔开
  • 常量使用以下划线分隔的大写命名
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,830评论 5 468
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,992评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,875评论 0 331
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,837评论 1 271
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,734评论 5 360
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,091评论 1 277
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,550评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,217评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,368评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,298评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,350评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,027评论 3 315
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,623评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,706评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,940评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,349评论 2 346
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,936评论 2 341