python代码格式规范

目前的规范基于pep-0008

基本格式

缩进

使用4个空格进行缩进

行宽

每行代码尽量不超过80个字符

理由:

  • 这在查看side-by-side的diff时很有帮助
  • 方便在控制台下查看代码
  • 太长可能是设计有缺陷

换行

Python支持括号内的换行。这时有两种情况。

  1. 第二行缩进到括号的起始处
foo = long_function_name(var_one, var_two,
                         var_three, var_four)
  1. 第二行缩进4个空格,适用于起始括号就换行的情形
def long_function_name(
        var_one, var_two, var_three,
        var_four):
    print(var_one)

使用反斜杠\换行,二元运算符+ .等应出现在行首,并与上一行的.=对齐;或者缩进4个空格。长字符串也可以用此法换行

foo = variable_with_long_name     + another_variable     + variable

session.query(MyTable)        .filter_by(id=1)        .one()

this_is_a_very_long(function_call, ‘with many parameters‘)     .that_returns_an_object_with_an_attribute

print ‘Hello, ‘       ‘%s %s!‘ %       (‘Harry‘, ‘Potter‘)

多个元素的list或者tuple,在起始括号后换行,第二行缩进4个空格

items = [
    ‘this is the first‘, ‘set of items‘, ‘with more items‘,
    ‘to come in this line‘, ‘like this‘
]

禁止复合语句,即一行中包含多个语句:

# yes
do_first()
do_second()
do_third()

# no
do_first();do_second();do_third();

if/for/while一定要换行:

# yes
if foo == ‘blah‘:
    do_blah_thing()

# no
if foo == ‘blah‘: do_blash_thing()

空行

  • 模块级函数和类定义之间空两行;
  • 类成员函数之间空一行;
  • 不要使用太多的连续空行来区分代码的逻辑块
class A:
    """This is a simple docstring."""

    def __init__(self):
        pass

    def hello(self):
        pass

def hello(name):
    print "Hello %s!" % name

def main():
    pass
  • 可以使用多个空行分隔多组相关的函数
  • 函数中可以使用空行分隔出逻辑相关的代码

表达式

空格

  • 一元运算符不加空格
  • 在二元运算符两边各空一格[=,-,+=,==,>,in,is not, and]:
# yes
exp = -1.05
i = i + 1
submitted += 1
x = x * 2 - 1
hypot2 = x * x + y * y
c = (a + b) * (a - b)

# no
exp = - 1.05
i=i+1
submitted +=1
x = x*2 - 1
hypot2 = x*x + y*y
c = (a+b) * (a-b)
  • 函数的参数列表中,,之后要有空格
# yes
def complex(real, imag):
    pass

# no
def complex(real,imag):
    pass
  • 函数的参数列表中,默认值等号两边不要添加空格
# yes
def complex(real, imag=0.0):
    pass

# no
def complex(real, imag = 0.0):
    pass
  • 左括号之后,右括号之前不要加多余的空格
# yes
spam(ham[1], {eggs: 2})
value = my_list[index]

# no
spam( ham[1], { eggs : 2 } )
value = my_list[ index ]
  • 字典、列表对象的左括号之前不要多余的空格
# yes
dict[‘key‘] = list[index]

# no
dict [‘key‘] = list [index]
  • 不要为对齐赋值语句而使用的额外空格
# yes
x = 1
y = 2
long_variable = 3

# no
x             = 1
y             = 2
long_variable = 3

比较

  • 使用变量在左,常量在右
  • 不显示进行对TrueFalse的比较
  • 否定比较采用,foo not in bar的形式,而不是not foo in bar
  • 使用instance(a, C)进行实例的类型检查,而不是type(A) is C
# yes
if method == ‘md5‘:
    pass
if not foo:
    pass
if foo not in bar:
    pass
if instance(a, C):
    pass
# no

if ‘md5‘ == method:
    pass
if foo == False:
    pass
if not foo in bar:
    pass
if type(A) is C:
    pass

引号

简单说,自然语言使用双引号,机器标示使用单引号,因此 代码里 多数应该使用 单引号

  • 自然语言 使用双引号 "..."
    例如错误信息;很多情况还是unicode,使用u"你好世界"
  • 机器标识 使用单引号 ‘...‘ 例如dict里的key
  • 正则表达式 使用原生的双引号 r"..."
  • 文档字符 使用三个双引号 """......"""

import语句

  • import语句应该分行书写
# yes
import os
import sys

# no
import sys,os

# yes
from subprocess import Popen, PIPE
  • import语句应该使用 absolute import
# yes
from foo.bar import Bar

# no
from ..bar import Bar
  • import语句应该放在文件头部,置于模块说明及docstring之后,于全局变量之前;
  • import语句应该按照顺序排列,每组之间用空行分隔
import os
import sys

import msgpack
import zmq

import foo
  • 导入其他模块的类定义时,可以使用相对导入
from myclass import MyClass
  • 如果发生命名冲突,则可使用命名空间
import bar
import foo.bar

bar.Bar()
foo.bar.Bar()

注释

块注释

#号后空一格,段落间用空行分开(同样需要#号)

# 块注释
# 块注释
#
# 块注释
# 块注释

行注释

至少使用两个空格和语句分开,使用有意义的注释

# yes
x = x + 1  # 边框加粗一个像素

# no
x = x + 1 # x加1 

docstring

docstring的规范在 PEP 257 中有详细描述,其中最其本的两点:

  1. 所有的公共模块、函数、类、方法,都应该写docstring。私有方法不一定需要,但应该在def后提供一个块注释来说明。
  2. docstring的结束"""应该独占一行,除非此docstring只有一行。
"""Return a foobar
Optional plotz says to frobnicate the bizbaz first.
"""

"""Oneline docstring"""

命名规范

  • 应避免使用小写字母l(L),大写字母O(o)I(i)单独作为一个变量的名称,以区分数字10
  • 包和模块使用全小写命名,尽量不要使用下划线
  • 类名使用CamelCase命名风格,内部类可用一个下划线开头;
    约定的缩写保留原样,例如使用HTTPWriter而不是HttpWriter
  • 函数使用下划线分隔的小写命名,lowercase_with_underscores
  • 当参数名称和Python保留字冲突,可在最后添加一个下划线,尽量不是使用缩写或自造的词
  • 常量使用以下划线分隔的大写命名,UPPERCASE_WITH_UNDERSCORES
  • Precompiled regular expressions: name_re
MAX_OVERFLOW = 100

Class FooBar:

    def foo_bar(self, print_):
        print(print_)
    

Function and method arguments:

  • Class methods: cls as first parameter.
  • Instance methods: self as first parameter.
  • Lambdas for properties may have the first parameter replaced with x, as in display_name = property(lambda x: x.real_name or x.username).

编码

  • 文件使用UTF-8编码
  • 文件头部加入#-*-coding:utf-8-*-标识
时间: 2024-08-04 13:53:39

python代码格式规范的相关文章

PEP 8 -- Python代码格式规则

目录 PEP 8 -- Python代码格式规则 概述 教条主义是脑袋瓜中的小妖精 代码布局 缩进 制表符还是空格? 单行最大长度 该在二元运算符的前面还是后面换行 空行 源文件代码编写 导入 模块级双下名称 字符串的引号 表达式和语句中的空格 痛点 其他建议 何时使用收尾逗号 注释 块注释 行内注释 文档字符串 命名规范 最高原则 描述性:命名样式 约定俗成:名称传统 避免使用的名称 ASCII 兼容 包和模块名 类名 Type变量名 异常类名 全局变量名 函数和变量名 函数和方法的参数 方法

Android开发代码格式规范

书写规范 1. 编码方式统一用UTF-8. Android Studio默认已是UTF-8,只要不去改动它就可以了. 2. 缩进统一为4个空格,将Tab size设置为4则可以保证tab键按4个空格缩进.另外,不要勾选上Use tab character,可以保证切换到不同tab长度的环境时还能继续保持统一的4个空格的缩进样式. 3. 花括号不要单独一行,和它前面的代码同一行.而且,花括号与前面的代码之间用一个空格隔开. public void method() { // Good } publ

Python代码编写规范,你真的会吗?

前言 本文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理.作者:yangjiajia123456  最近两年的工作都是和运维相关,有时运维人员也会写一些python程序,但基本上都没有遵循相应的代码规范,一向粗暴,能用就行,既不考虑可读性也不考虑可维护性,作为一个开发人员有时候看他们写代码就很不舒服,今天就谈谈python写代码时的一些规范.如果你刚学python.不久遇到问题多,建议可以来小编的Python交流.裙 :一久武其而

python代码PEP8规范示例

""" 文档字符串 docstring, 是 package, module, class, method, function 级别的注释,可以通过 doc 成员访问到,注释内容在一对双引号 优先使用英文写注释,英文不好全部写中文,强行使用英文可能导致大家都看不懂 1.所有 import 尽量放在文件开头,在 docstring 下面,其他变量定义的上面 2.不要使用 from foo import * 3.import 需要分组,每组之间一个空行,每个分组内的顺序尽量采用字

Python代码编写规范

编码: a)     如无特殊情况,文件一律使用UTF-8编码 b)     如无需特殊情况,文件头部必须加入#-*-coding:utf-8-*- 缩进 a)     统一使用4个空格进行缩进 引号 a)     自然语言使用双引号"-.",正则表达式使用原生的双引号r"" b)     机器标识使用单引号'' c)      文档字符串(docstring)使用三个双引号"""-""" 空行 a)   

(转)Python PEP8 编码规范中文版

转:https://blog.csdn.net/ratsniper/article/details/78954852 原文链接:http://legacy.python.org/dev/peps/pep-0008/ item detail PEP 8 Title Style Guide for Python Code Version c451868df657 Last-Modified 2016-06-08 10:43:53 -0400 (Wed, 08 Jun 2016) Author Gui

Effective Python之编写高质量Python代码的59个有效方法

                                                     这个周末断断续续的阅读完了<Effective Python之编写高质量Python代码的59个有效方法>,感觉还不错,具有很大的指导价值.下面将以最简单的方式记录这59条建议,并在大部分建议后面加上了说明和示例,文章篇幅大,请您提前备好瓜子和啤酒! 1. 用Pythonic方式思考 第一条:确认自己使用的Python版本 (1)有两个版本的python处于活跃状态,python2和pyt

编写高质量Python代码的59个有效方法(转)

第一条:确认自己使用的Python版本 (1)有两个版本的python处于活跃状态,python2和python3 (2)有很多流行的Python运行时环境,CPython.Jython.IronPython以及PyPy等 (3)在开发项目时,应该优先考虑Python3 第二条:遵循PEP风格指南 PEP8是针对Python代码格式而编订的风格指南,参考:http://www.python.org/dev/peps/pep-0008 (1)当编写Python代码时,总是应该遵循PEP8风格指南

Python的编码规范

7. 什么是 PEP8? 8号Python增强提案,是针对Python代码格式而编写的风格指南 8. 了解 Python 之禅么? 通过 import this 语句可以获取其具体的内容.它告诉大家何写出高效整洁的代码 Beautiful is better than ugly. Explicit is better than implicit. Simple is better than complex. Complex is better than complicated. Flat is