python的统一编码规范
请注意这一点:没有编码规范的代码没有阅读价值,也更谈不上复用。
目前业界比较流行的Python的编码规范目前主要有PEP8的编程、Google的编码风格、Python Guide和Pocoo StyleGuide等等,我认为无论是哪一种编码规范和风格,最重要的是要在团队中有一套统一或者近乎一致的编码规范和风格,这样才能确保协作效率和降低沟通成本。目前我所在的团队并没有一套规范,那么这个伟大的任务又要落在我手里来实现啦,哇哈哈:-D。
先说明一下,设计这套统一编码规范的原则只有一个:Simple is the best,简单实用是核心指导原则,编码规范要符合编码习惯和提升代码可读性。这套编码规范是基于PEP8规范的,但是同时参考Google的编码风格和大神编写的"Strunk & White"风格。
命名
文件名、包名、模块名:全小写,使用下划线可以改善可读性可以加入,如my_package。
类:总是使用首字母大写单词串。如MyClass。
函数、方法:函数名应该为小写,可以用下划线风增加可读性,如my_example_function。
变量:小写,尽量避免单字母变量,尽量让变量有意义。
常量:要求全部字幕大写,可以用下划线风增加可读性,如GLOBAL_VAR_NAME。
内部(Internal):使用(_)开头表示模块变量或函数是protected 的(使用import * from时不会包含);使用(__)开头表示实例变量或方法表示类内私有,类实例不能调用。
缩写:名中含有长单词,对某个单词进行缩写。这时应使用约定成俗的缩写方式。 例如:function 缩写为 fn;text 缩写为 txt ;object 缩写为 obj ;count 缩写为 cnt;number 缩写为 num 等。
布局
最重要的话写在第一句:如果懒得跟我一样的话,使用pycharm IDE用快捷键Ctrl+Alt+L就可以完成统一的代码布局。
在不使用这个IDE或者忘了用快捷键的情况下,请注意以下统一的代码布局:
代码长度:每行不超过80个字符。这一点pycharm没有这么严格,但是希望大家尽力做到,这样确保其他同事可以轻松愉快地阅读每一行代码。
空行:用两行空行分割顶层函数和类的定义,类内方法的定义用单个空行分割。
缩进:使用4个空格作为一个缩进层次,尽量不要用8个空格。
分号:不要使用分号,尽管是用了也没有错。
括号:括号使用原则是越少越好,不要在返回语句或者条件语句中使用括号,例如:


空格(请尽量不要用制表符TAB,如果用了请保持一致):
括号内不使用空格;

不在逗号和冒号前使用空格,在其后面添加(跟英文写作一样);

二元操作符 【赋值(=), 比较(==, <, >, !=, <>, <=, >=, in, notin, is, is not), 布尔(and, or, not)】两边都使用空格,

参数列表里不要带空格

以上截图来自《Google python style guide》
注释
python单行注释用#字符开头即可注释后面的内容,对于重要语句进行注释包括解释说明和提醒的作用。 python多行注释可以用’’’或者”””开头并以相同的用’’’或者”””结尾即可注释多行语句。
特别说明: python的方法内置对象doc String ,它可以用于模块、函数和类的描述,在写方法的时候,只要在方法声明下面进行多行注释。在引用或者使用的场景下,可以通过dir或者help方法可以查看该方法的使用帮助。python的方法注释可以参照下图,pycharm支持自动生成注释,比较方便。

Python 有一种独一无二的的注释方式: 使用文档字符串. 文档字符串是包, 模块, 类或函数里的第一个语句. 这些字符串可以通过对象的__doc__成员被自动提取, 并且被pydoc 所用. (你可以在你的模块上运行pydoc 试一把, 看看它长什么样). 我们对文档字符串的惯例是使用三重双引号. 一个文档字符串应该这样组织: 首先是一行以句号, 问号或惊叹号结尾的概述. 接着是一个空行. 接着是文档字符串剩下的部分, 它应该与文档字符串的第一行的第一个引号对齐。注意上图中的函数注释,文档字符串应该包含函数做什么, 以及输入和输出的详细描述. 通常, 不应该描述”怎么做”, 除非是一些复杂的算法. 对于技巧性的代码, 块注释或者行内注释是最重要的. 文档字符串应该提供足够的信息, 当别人编写代码调用该函数时, 他不需要看一行代码, 只要看文档字符串就可以了. 应该给参数单独写文档. 在冒号后跟上解释,
导入
可以使用两种导入的方法:
1.使用 import x 来导入包和模块。
2.使用 form x import y , 其中x 是包前缀, y 是不带前缀的模块名。
在后面讲述的common-lib库中,建议大家使用from common-lib import *这样的导入,在这个自定义库的__init__.py文件中已经定义了哪些可以导入哪些不需要导入。比较方便。
使用上述的导入方法的时候,要使用绝对路径而非相对路径,避免重复导入。
Main入口
要求所有新建的py文件都要有Main的入口,且必须总是检查该导如的主程序是否被执行。
Pycharm支持python代码模板,建议大家使用这个模板。
#-*- encoding:UTF-8 -*-
from __future__ import division
import sys __author__ = '$USER'
def main():
pass if __name__ == '__main__':
reload(sys)
print "START: system-encoding[%s]"%sys.getdefaultencoding()
main()
这个代码执行的时候先检查系统的编码,这个TIP是我踩过很多坑之后的教训,这样可以让你每次都知道当前程序运行的编码。
参考文档
《Google-Python-Style-Guide》
《Python开发编码规范(PEP8)》
《The Elements of Python Style》
python的统一编码规范的更多相关文章
- 学习笔记之Python最简编码规范
Python最简编码规范 - 机器学习算法与Python学习 https://mp.weixin.qq.com/s/i6MwvC4jYTE6D1KHFgBeoQ https://www.cnblogs ...
- Python 常用 PEP8 编码规范
Python 常用 PEP8 编码规范 代码布局 缩进 每级缩进用4个空格. 括号中使用垂直隐式缩进或使用悬挂缩进. EXAMPLE: ? 1 2 3 4 5 6 7 8 9 10 11 12 13 ...
- Python PEP 8 编码规范中文版
原文链接:http://legacy.python.org/dev/peps/pep-0008/ 转发链接:https://blog.csdn.net/ratsniper/article/detail ...
- Python最简编码规范
前言 本文是阅读<Python Coding Rule>之后总结的最为精华及简单的编码规范,根据每个人不同喜好有些地方会有不同的选择,我只是做了对自己来说最简单易行的选择,仅供大家参考. ...
- Python第一章-编码规范
Python的基础知识 一.编码规范 PEP8[^ 注] 编码规范 Guido的关键点之一是:代码更多是用来读而不是写.编码规范旨在改善Python代码的可读性. 风格指南强调一致性.项目.模块或函数 ...
- 【转】python - PyDev统一编码
http://www.cnblogs.com/huangjacky/archive/2012/07/15/2592166.html 我们都知道Win7默认编码是GBK,而Ubuntu下面默认是utf- ...
- Python基础:编码规范(4)
1.命名规范 Python中不同代码元素采用不同命名方式: ◊ 包名:全部小写字母,中间可以由点分隔开.作为命名空间,包名需具有唯一性. ◊ 模块名:全部小写字母,如果是多个单词构成,使用下划线分隔. ...
- [python]python官方原版编码规范路径
1.进入python官方主页:https://www.python.org/ 2.按如下图进入PEP Index 3.选择第8个,即为python的规范
- Python 常用 PEP8 编码规范和建议
代码布局 缩进 每级缩进用4个空格. 括号中使用垂直隐式缩进或使用悬挂缩进. EXAMPLE: # (垂直隐式缩进)对准左括号 foo = long_function_name(var_one, va ...
随机推荐
- 【Android 应用开发】Android 图表绘制 achartengine 示例解析
作者 : 韩曙亮 转载请注明出处 : http://blog.csdn.net/shulianghan/article/details/38420197 一. AChartEngine 简介 1. 项 ...
- python调用数据库并查询
http://blog.csdn.net/pipisorry/article/details/48024795 python调用数据库命令 conn = sqlite3.connect(". ...
- AngularJS进阶(二十九)AngularJS项目开发技巧之localStorage存储
AngularJS项目开发技巧之localStorage存储 注: localStorage深度学习 绪 项目开发完毕,测试阶段发现后台管理端二维码生成有问题,问题在于localStora ...
- 在Cocos2D中改变动态物体为静态物体
原文链接,有压缩和简化 1.导入一个新的头文件 首先你要知道,不是所有Chimpunk特性都通过Cocos2d的类暴露出来,比如CCPhysicsNode和CCPhysicsBody.对于一些更高级的 ...
- tomcat生产部署关键参数设置
JVM设置 个节点,每个tomcat预计处理500个链接,那么连接池的长连接数最大设为2000. 全节点复制(DeltaManager)模式集群节点数3-6为宜. 主备复制(BackupMnagage ...
- saiku显示不出新的cube(加载的cube,saiku会保存到缓存中,不重新加载)
当用workbench 修改cube后,保存到saiku路径. saiku读取该cube时,如果以前加载过该cube(同路径,同名).则不会新加载,而是用缓存中的cube,这个cube是以前的cube ...
- AngularJS进阶(十九)在AngularJS应用中集成百度地图实现定位功能
在AngularJS应用中集成百度地图实现定位功能 注:请点击此处进行充电! 前言 根据项目需求,需要实现手机定位功能,考虑到百度业务的强大能力,遂决定使用百度地图第三方服务. 添加第三方模块的步骤与 ...
- windows linux—unix 跨平台通信集成控制系统----系统硬件信息获取
控制集成系统需要了解系统的各项硬件信息,之前我们设计的时候,习惯使用c函数来搞,后来可能发现程序的移植性收到了一些影响,比如unix内核的一些c函数在linux下面是没有的: 比如 苹果达尔文内核的如 ...
- LeetCode之“动态规划”:Decode Ways
题目链接 题目要求: A message containing letters from A-Z is being encoded to numbers using the following map ...
- Apache Hadoop 2.0.2-alpha
原文出处http://hadoop.apache.org/docs/r2.0.2-alpha/hadoop-yarn/hadoop-yarn-site/Federation.html HDFSF分为2 ...