• Python 之 风格规范(Google )


    开头先mark一下网址:goole官网

    任何语言的程序员,编写出符合规范的代码,是开始程序生涯的第一步。

    一、分号

    不要在行尾加分号, 也不要用分号将两条命令放在同一行。

    二、行长度

     每行不超过80个字符

    例外:

    1. 长的导入模块语句
    2. 注释里的URL

    不要使用反斜杠连接行.

    Python会将 圆括号, 中括号和花括号中的行隐式的连接起来 , 你可以利用这个特点. 如果需要, 你可以在表达式外围增加一对额外的圆括号.

    Yes: foo_bar(self, width, height, color='black', design=None, x='foo',
                 emphasis=None, highlight=0)
    
         if (width == 0 and height == 0 and
             color == 'red' and emphasis == 'strong'):

    如果一个文本字符串在一行放不下, 可以使用圆括号来实现隐式行连接

    x = ('This will build a very long long '
         'long long long long long long string')

    在注释中,如果必要,将长的URL放在一行上。

    Yes: # See details at # http://www.example.com/us/developer/documentation/api/content/v2.0/csv_file_name_extension_full_specification.html

    No:  # See details at
         # http://www.example.com/us/developer/documentation/api/content/
         # v2.0/csv_file_name_extension_full_specification.html

    三、括号

    宁缺毋滥的使用括号

    除非是用于实现行连接, 否则不要在返回语句或条件语句中使用括号. 不过在元组两边使用括号是可以的.

    四、缩进

    用4个空格来缩进代码

    绝对不要用tab, 也不要tab和空格混用.

    对于行连接的情况, 你应该要么垂直对齐换行的元素(见 行长度 部分的示例),或者使用4空格的悬挂式缩进(这时第一行不应该有参数):

    五、空行

    顶级定义之间空两行, 方法定义之间空一行
    • 顶级定义之间空两行, 比如函数或者类定义.
    • 方法定义, 类定义与第一个方法之间, 都应该空一行. 函数或方法中, 某些地方要是你觉得合适, 就空一行.

    六、空格

    按照标准的排版规范来使用标点两边的空格
    1. 括号内不要有空格.
    2. 不要在逗号, 分号, 冒号前面加空格, 但应该在它们后面加(除了在行尾).
    3. 参数列表, 索引或切片的左括号前不应加空格.
    4. 在二元操作符两边都加上一个空格, 比如赋值(=), 比较(==, <, >, !=, <>, <=, >=, in, not in, is, is not), 布尔(and, or, not). 至于算术操作符两边的空格该如何使用, 需要你自己好好判断. 不过两侧务必要保持一致.
    5. 当’=’用于指示关键字参数或默认参数值时, 不要在其两侧使用空格.
    6. 不要用空格来垂直对齐多行间的标记, 因为这会成为维护的负担(适用于:, #, =等)

    七、Shebang

    大部分.py文件不必以#!作为文件的开始. 根据 PEP-394 , 程序的main文件应该以 #!/usr/bin/python2或者 #!/usr/bin/python3开始.

    (译者注: 在计算机科学中, Shebang (也称为Hashbang)是一个由井号和叹号构成的字符串行(#!), 其出现在文本文件的第一行的前两个字符. 在文件中存在Shebang的情况下, 类Unix操作系统的程序载入器会分析Shebang后的内容, 将这些内容作为解释器指令, 并调用该指令, 并将载有Shebang的文件路径作为该解释器的参数. 例如, 以指令#!/bin/sh开头的文件在执行时会实际调用/bin/sh程序.)

    #!先用于帮助内核找到Python解释器, 但是在导入模块时, 将会被忽略. 因此只有被直接执行的文件中才有必要加入#!.

    八、注释

    确保对模块, 函数, 方法和行内注释使用正确的风格

    块注释和行注释

    最需要写注释的是代码中那些技巧性的部分. 如果你在下次 代码审查 的时候必须解释一下, 那么你应该现在就给它写注释. 对于复杂的操作, 应该在其操作开始前写上若干行注释. 对于不是一目了然的代码, 应在其行尾添加注释.

    为了提高可读性, 注释应该至少离开代码2个空格.

    另一方面, 绝不要描述代码. 假设阅读代码的人比你更懂Python, 他只是不知道你的代码要做什么.

    九、类

    如果一个类不继承自其它类, 就显式的从object继承. 嵌套类也一样.

    继承自 object 是为了使属性(properties)正常工作, 并且这样可以保护你的代码, 使其不受 PEP-3000 的一个特殊的潜在不兼容性影响. 这样做也定义了一些特殊的方法, 这些方法实现了对象的默认语义, 包括

    __new__, __init__, __delattr__, __getattribute__, __setattr__, __hash__, __repr__, and __str__

    十、字符串

    即使参数都是字符串, 使用%操作符或者格式化方法格式化字符串. 不过也不能一概而论, 你需要在+和%之间好好判定.

    避免在循环中用+和+=操作符来累加字符串. 由于字符串是不可变的, 这样做会创建不必要的临时对象, 并且导致二次方而不是线性的运行时间. 作为替代方案, 你可以将每个子串加入列表, 然后在循环结束后用 .join 连接列表. (也可以将每个子串写入一个 cStringIO.StringIO 缓存中.)

    十一、文件和sockets

    在文件和sockets结束时, 显式的关闭它.

    十二、TODO注释

    为临时代码使用TODO注释, 它是一种短期解决方案. 不算完美, 但够好了.

    十三、导入格式

    每个导入应该独占一行

    导入总应该放在文件顶部, 位于模块注释和文档字符串之后, 模块全局变量和常量之前. 导入应该按照从最通用到最不通用的顺序分组:

    1. 标准库导入
    2. 第三方库导入
    3. 应用程序指定导入

    每种分组中, 应该根据每个模块的完整包路径按字典序排序, 忽略大小写.

    十四、语句

    通常每个语句应该独占一行

    不过, 如果测试结果与测试语句在一行放得下, 你也可以将它们放在同一行.

    如果是if语句, 只有在没有else时才能这样做. 特别地, 绝不要对 try/except 这样做, 因为try和except不能放在同一行.

    十五、访问控制

    在Python中, 对于琐碎又不太重要的访问函数, 你应该直接使用公有变量来取代它们, 这样可以避免额外的函数调用开销. 当添加更多功能时, 你可以用属性(property)来保持语法的一致性.
    
    (译者注: 重视封装的面向对象程序员看到这个可能会很反感, 因为他们一直被教育: 所有成员变量都必须是私有的! 其实, 那真的是有点麻烦啊. 试着去接受Pythonic哲学吧)

    十六、命名

    module_name, package_name, ClassName, method_name, ExceptionName, function_name, GLOBAL_VAR_NAME, instance_var_name, function_parameter_name, local_var_name.

    应该避免的名称

    1. 单字符名称, 除了计数器和迭代器.
    2. 包/模块名中的连字符(-)
    3. 双下划线开头并结尾的名称(Python保留, 例如__init__)

    命名约定

    1. 所谓”内部(Internal)”表示仅模块内可用, 或者, 在类内是保护或私有的.
    2. 用单下划线(_)开头表示模块变量或函数是protected的(使用import * from时不会包含).
    3. 用双下划线(__)开头的实例变量或方法表示类内私有.
    4. 将相关的类和顶级函数放在同一个模块里. 不像Java, 没必要限制一个类一个模块.
    5. 对类名使用大写字母开头的单词(如CapWords, 即Pascal风格), 但是模块名应该用小写加下划线的方式(如lower_with_under.py). 尽管已经有很多现存的模块使用类似于CapWords.py这样的命名, 但现在已经不鼓励这样做, 因为如果模块名碰巧和类名一致, 这会让人困扰.

                               Python之父Guido推荐的规范

    TypePublicInternal
    Modules lower_with_under _lower_with_under
    Packages lower_with_under  
    Classes CapWords _CapWords
    Exceptions CapWords  
    Functions lower_with_under() _lower_with_under()
    Global/Class Constants CAPS_WITH_UNDER _CAPS_WITH_UNDER
    Global/Class Variables lower_with_under _lower_with_under
    Instance Variables lower_with_under _lower_with_under (protected) or __lower_with_under (private)
    Method Names lower_with_under() _lower_with_under() (protected) or __lower_with_under() (private)
    Function/Method Parameters lower_with_under  
    Local Variables lower_with_under  

    十七、Main

    即使是一个打算被用作脚本的文件, 也应该是可导入的. 并且简单的导入不应该导致这个脚本的主功能(main functionality)被执行, 这是一种副作用. 主功能应该放在一个main()函数中.
  • 相关阅读:
    C# 单例模式
    [C# 线程处理系列]专题四:线程同步
    C#实现远程开机(局域网测试通过)
    C#实现类只实例化一次(被多个类访问调用)
    c#委托与事件、消息、WndProc用法(转)
    UML 类图常用表示方法.
    C# Socket 接受数据不全的处理
    执行数据库操作失败: 连接未关闭。 连接的当前状态为打开
    hdu 2018 母牛的故事 动态规划入门题
    Codeforces 1029B. Creating the Contest 动态规划O(nlogn)解法 及 单调队列O(n)解法
  • 原文地址:https://www.cnblogs.com/lzhh/p/python_2.html
Copyright © 2020-2023  润新知