python 编码规范整理


Posted in Python onMay 05, 2018

一 代码编排

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 块注释,在一段代码前增加的注释。在‘#'后加一空格。段落之间以只有‘#'的行间隔。

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的方式。

以上就是在pytho开发过程中的一些注意的点!

Python 相关文章推荐
Python实现HTTP协议下的文件下载方法总结
Apr 20 Python
python下载图片实现方法(超简单)
Jul 21 Python
pandas DataFrame 根据多列的值做判断,生成新的列值实例
May 18 Python
在Python中Dataframe通过print输出多行时显示省略号的实例
Dec 22 Python
这可能是最好玩的python GUI入门实例(推荐)
Jul 19 Python
详解python中__name__的意义以及作用
Aug 07 Python
Python 实用技巧之利用Shell通配符做字符串匹配
Aug 23 Python
详解Python3 pickle模块用法
Sep 16 Python
python实现数字炸弹游戏
Jul 17 Python
10个示例带你掌握python中的元组
Nov 23 Python
用Python将库打包发布到pypi
Apr 13 Python
Python基础知识学习之类的继承
May 31 Python
PYTHON基础-时间日期处理小结
May 05 #Python
python 日期操作类代码
May 05 #Python
Python批量发送post请求的实现代码
May 05 #Python
PyQt5 pyqt多线程操作入门
May 05 #Python
详解pyqt5 动画在QThread线程中无法运行问题
May 05 #Python
python中in在list和dict中查找效率的对比分析
May 04 #Python
Django如何配置mysql数据库
May 04 #Python
You might like
正义联盟的终局之战《天启星战争》将成为DC动画宇宙的最后一部
2020/04/09 欧美动漫
PHP 分页原理分析,大家可以看看
2009/12/21 PHP
在php和MySql中计算时间差的方法
2011/04/22 PHP
php批量上传的实现代码
2013/06/09 PHP
浅析php与数据库代码开发规范
2013/08/08 PHP
Jquery 动态循环输出表格具体方法
2013/11/23 Javascript
Javascript中的异步编程规范Promises/A详细介绍
2014/06/06 Javascript
js使用onmousemove和onmouseout获取鼠标坐标的方法
2015/03/31 Javascript
JavaScript快速切换繁体中文和简体中文的方法及网站支持简繁体切换的绝招
2016/03/07 Javascript
必备的JS调试技巧汇总
2016/07/20 Javascript
JavaScript实现垂直向上无缝滚动特效代码
2016/11/23 Javascript
vue+swiper实现侧滑菜单效果
2017/12/28 Javascript
js实现微信/QQ直接跳转到支付宝APP打开口令领红包功能
2018/01/09 Javascript
js比较两个单独的数组或对象是否相等的实例代码
2019/04/28 Javascript
构建大型 Vue.js 项目的10条建议(小结)
2019/11/14 Javascript
如何使用three.js 制作一个三维的推箱子游戏
2020/07/29 Javascript
python3图片转换二进制存入mysql
2013/12/06 Python
使用python 获取进程pid号的方法
2014/03/10 Python
python中sleep函数用法实例分析
2015/04/29 Python
从源码解析Python的Flask框架中request对象的用法
2016/06/02 Python
Python实现类似jQuery使用中的链式调用的示例
2016/06/16 Python
Request的中断和ErrorHandler实例解析
2018/02/12 Python
Python使用Scrapy爬虫框架全站爬取图片并保存本地的实现代码
2018/03/04 Python
解决Python下json.loads()中文字符出错的问题
2018/12/19 Python
python flask web服务实现更换默认端口和IP的方法
2019/07/26 Python
Python如何通过Flask-Mail发送电子邮件
2020/01/29 Python
Python dict和defaultdict使用实例解析
2020/03/12 Python
彼得罗夫美国官网:Peter Thomas Roth美国(青瓜面膜)
2017/11/05 全球购物
Volcom英国官方商店:美国殿堂级滑板、冲浪、滑雪服装品牌
2019/03/13 全球购物
《三个小伙伴》教学反思
2014/04/11 职场文书
群众路线教育实践活动批评与自我批评
2014/09/15 职场文书
检察院院长群众路线教育实践活动个人整改措施
2014/10/04 职场文书
个人自查自纠材料
2014/10/14 职场文书
小学中等生评语
2014/12/29 职场文书
实习护士自荐信
2015/03/25 职场文书
MySQL时区造成时差问题
2022/04/13 MySQL