python代码规范

转自:https://www.jianshu.com/p/8b6c425b65a6

前言

python学习之旅,先来看看python的代码规范,让自己先有个意识,而且在往后的学习中慢慢养成习惯。

目录

python代码规范.png

一,简明概述

1.编码

  • 如无特殊情况,文件一律使用utf-8编码
  • 如无特殊情况,文件头部必须加入# -*-coding:utf-8-*-

2.代码格式

2.1.缩进

  • 统一使用4个空格进行缩进

2.2.行宽

每行代码最好不要超过80个字符(在特殊情况下可以超过80个,但最好不要超过120个)
理由:

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

2.3.引号

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

  • 自然语言使用双引号"..."
    例如错误信息,很多时候还是unicode,使用u"你好,世界"
  • 机器标识使用单引号'...'
    例如字典里的key
  • 正则表达式使用原生的双引号r"..."
  • 文档字符串(docstring)使用三个双引号"""..."""

2.4. 空行

  • 模块级函数和类之间空两行
  • 类成员函数之间空一行
class A:

      def __init__(self): # 类成员函数
          pass

      def hello(self): # 类成员函数
          pass

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

2.5.编码

  • 文件使用utf-8编码
  • 文件头部键入# -*-coding:utf-8-*-标识

3.import语句

  • import语句应该分行书写
# 正确的写法
import os
import sys

# 不推荐的写法
import os,sys

# 正确的写法
from subprocess import Popne, PIPE
  • import语句应该使用absolute import
# 正确的写法
from foo.bar import Bar

# 不推荐的写法
from ..bar import Bar
  • import 语句应该放在文件头部,置于模块说明及docstring之后,与全局变量之前
  • import语句应该按照顺序排序,每组之间用一个空行分割
import os
import sys

import lxml
import bs4

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

bar.get()
foo.bar.get()

4.空格

  • 在二元操作符两边各空一格[=,-,+=,-=,==,is not,and,in]
# 正确的写法
i = i + 1
y += 1
z = x * x + y * y
c = (a + b) + (a - b)

# 不推荐的写法
i=i+1
y+=1
z=x*x+y*y
c=(a+b)+(a-b)
  • 函数的参数列表中,,之后加空格
# 正确的写法
def foo(var1, var2):
    pass

# 不推荐的写法
def bar(var1,var2):
    pass
  • 函数的参数列表中,默认值等号两边不要加空格
# 正确的写法
def foo(var1, var2=1):
    pass

# 不推荐的写法
def bar(var1, var2 = 1):
    pass

  • 左括号之后,右括号之前不要加多余的空格
# 正确的写法
def foo(var1, var2):
    pass

# 不推荐的写法
def bar( var1, var2 ):
    pass

  • 字典对象的左括号之前不要添加多余的空格
# 正确的写法
dict1['key'] = 1

# 不推荐的写法
dict1 ['key'] = 1
  • 不要为对齐赋值语句而使用额外的空格
# 正确的写法
x = 1
y = 2
long_variable = 3

# 不推荐的写法
x             = 1
y             = 2
long_variable = 3

5.换行

python支持括号内的换行,这时有2种情况
1.第二行缩进到括号的起始处

foo = long_function_name(var1, var2
                         var3, var4)

2.第二行缩进4个空格,适用于起始括号就换行的情况

def long_function_name(
              var1, var2
              var3, var4):
              print(var1)

使用反斜杠\换行,二元运算符+ .等应该出现在行末;长字符串也应该用此法换行

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

print 'Hello, '\
      '%s %s!' %\
      ('Harry', 'Potter')

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

#正确的写法
do_first()
do_second()
do_third()

#不推荐的写法
do_first();do_second();do_third();

if/for/while一定要换行:

#正确的写法
if foo == 'blash':
  do_something()

#不推荐的写法
if foo == 'blash':do_something()

6.docstring

docstring中最规范的2点:
1.所有的公共模块,类,函数,方法。私有方法不一定需要,但应该在def后提供一个块注释来说明
1.docstring的结束符'''应该独占一行,除非这个doctring只占一行

"""Return a foobar
Optional plotz says to frobnicate the bizbaz first.
"""

"""Oneline docstring"""

二,注释

1.注释

1.1.块注释

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

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

1.2.行注释

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

# 正确的写法
x = x + 1  # 边框加粗一个像素

# 不推荐的写法(无意义的注释)
x = x + 1 # x加1

1.3.建议

  • 在代码的关键部分(或比较复杂的地方), 能写注释的要尽量写注释
  • 比较重要的注释段, 使用多个等号隔开, 可以更加醒目, 突出重要性
app = create_app(name, options)


# =====================================
# 请勿在此处添加 get post等app路由行为 !!!
# =====================================


if __name__ == '__main__':
    app.run()

2.文档注释(Docstring)

作为文档的Docstring一般出现在模块头部、函数和类的头部,这样在python中可以通过对象的doc对象获取文档.
编辑器和IDE也可以根据Docstring给出自动提示.

  • 文档注释以 """ 开头和结尾, 首行不换行, 如有多行, 末行必需换行, 以下是Google的docstring风格示例
# -*- coding: utf-8 -*-
"""Example docstrings.

This module demonstrates documentation as specified by the `Google Python
Style Guide`_. Docstrings may extend over multiple lines. Sections are created
with a section header and a colon followed by a block of indented text.

Example:
    Examples can be given using either the ``Example`` or ``Examples``
    sections. Sections support any reStructuredText formatting, including
    literal blocks::

        $ python example_google.py

Section breaks are created by resuming unindented text. Section breaks
are also implicitly created anytime a new section starts.
"""
  • 不要在文档注释复制函数定义原型, 而是具体描述其具体内容, 解释具体参数和返回值等
#  不推荐的写法(不要写函数原型等废话)
def function(a, b):
    """function(a, b) -> list"""
    ... ...


#  正确的写法
def function(a, b):
    """计算并返回a到b范围内数据的平均值"""
    ... ...
  • 对函数参数、返回值等的说明采用numpy标准, 如下所示
def func(arg1, arg2):
    """在这里写函数的一句话总结(如: 计算平均值).

    这里是具体描述.

    参数
    ----------
    arg1 : int
        arg1的具体描述
    arg2 : int
        arg2的具体描述

    返回值
    -------
    int
        返回值的具体描述

    参看
    --------
    otherfunc : 其它关联函数等...

    示例
    --------
    示例使用doctest格式, 在`>>>`后的代码可以被文档测试工具作为测试用例自动运行

    >>> a=[1,2,3]
    >>> print [x + 3 for x in a]
    [4, 5, 6]
    """
  • 文档注释不限于中英文, 但不要中英文混用
  • 文档注释不是越长越好, 通常一两句话能把情况说清楚即可
  • 模块、公有类、公有方法, 能写文档注释的, 应该尽量写文档注释

3.命名规范

1.模块

  • 模块尽量使用小写命名,首字母保持小写,尽量不要用下划线(除非多个单词,且数量不多的情况)
# 正确的模块名
import decoder
import html_parser

# 不推荐的模块名
import Decoder

2.类名

  • 类名使用驼峰(CamelCase)命名风格,首字母大写,私有类可用一个下划线开头
class Farm():
    pass

class AnimalFarm(Farm):
    pass

class _PrivateFarm(Farm):
    pass
  • 将相关的类和顶级函数放在同一个模块里. 不像Java, 没必要限制一个类一个模块.

3.函数

  • 函数名一律小写,如有多个单词,用下划线隔开
def run():
    pass

def run_with_env():
    pass
  • 私有函数在函数前加一个下划线_
class Person():

    def _private_func():
        pass

4.变量名

  • 变量名尽量小写, 如有多个单词,用下划线隔开
if __name__ == '__main__':
    count = 0
    school_name = ''

- 常量采用全大写,如有多个单词,使用下划线隔开

MAX_CLIENT = 100
MAX_CONNECTION = 1000
CONNECTION_TIMEOUT = 600

5.常量

  • 常量使用以下划线分隔的大写命名
MAX_OVERFLOW = 100

Class FooBar:

    def foo_bar(self, print_):
        print(print_)
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,826评论 6 506
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,968评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,234评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,562评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,611评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,482评论 1 302
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,271评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,166评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,608评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,814评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,926评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,644评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,249评论 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,866评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,991评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,063评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,871评论 2 354

推荐阅读更多精彩内容