python 命名规则
# 命名规则
# 目录
1、包命名 mypackage,package_name (opens new window)
2、模块命名 mymodule.py,module_name.py (opens new window)
3、类命名 MyClass,ClassName (opens new window)
1)普通函数 myfunction(),my_function_name() (opens new window)
2)私有函数(外部访问会报错) __get_name() (opens new window)
3)函数和方法的参数 parameter,function_parameter_name (opens new window)
1)类变量(全局变量名) COLOR_WRITE,GLOBAL_VAR_NAME (opens new window)
2)常量 MAX_OVERFLOW,TOTAL (opens new window)
3)普通变量 this_is_a_var ,local_var_name (opens new window)
4)实例变量 _instance_var (opens new window)
5)私有实例变量(外部访问会报错) __private_var (opens new window)
6)专有变量 __class__ (opens new window)
6、异常命名 ExceptionNameError (opens new window)
9、Python关键字 (opens new window)
10、Python内置函数 (opens new window)
1)模块中,函数,类定义之间,空2行 (opens new window)
2)类成员函数之间,空1行 (opens new window)
3)在二元运算符两边,各空一格 [=,-,+=,==,>,in,is not, and] (opens new window)
4)函数的参数列表中,逗号之后,要有空格 (opens new window)
5)函数的参数列表中,默认值等号两边,不要添加空格 (opens new window)
6)左括号之后,右括号之前,不要加多余的空格 (opens new window)
7)字典对象的左括号之前,不要多余的空格 (opens new window)
8)不要为对齐赋值语句,而使用额外空格 (opens new window)
4、import 语句 (opens new window)
1)单独import时,不要在一行导入多个; (opens new window)
2)from ... import可以在一行导入多个 (opens new window)
3)import语句应该使用 absolute import (opens new window)
4)import语句书写位置 (opens new window)
5)如果发生命名冲突,则可使用命名空间 (opens new window)
1)禁止复合语句,即一行中包含多个语句 (opens new window)
2)if/for/while一定要换行 (opens new window)
4)使用反斜杠\换行,二元运算符+ .等应出现在行末 (opens new window)
3)文档注释(Docstring) (opens new window)
# 标志符
标识符,必须以字母、下画线(_)开头(数字不能打头),后面可以跟任意数目的字母、数字和下画线(_)。
字母并不局限于 26 个英文字母,可以包含中文字符、日文字符等。
Python 语言是区分大小写的,因此 abc 和 Abc 是两个不同的标识符。
标识符不能是 Python 关键字,但可以包含关键字。
标识符不能包含空格。
Python 3 支持 UTF-8 字符集,因此 Python 3 的标识符可以使用 UTF-8 所能表示的多种语言的字符
Python 2.x 对中文支持较差,如果要在 Python 2.x 程序中使用中文字符或中文变量,则需要在 Python 源程序的第一行增加“#coding:utf-8”,当然别忘了将源文件保存为 UTF-8 字符集
标识符例子:
- abc_xyz:合法。
- HelloWorld:合法。
- abc:合法。
- xyz#abc:不合法,标识符中不允许出现“#”号。
- abc1:合法。
- 1abc:不合法,标识符不允许数字开头。
# 1、包命名 mypackage,package_name
- 小写字母;
- 可使用下划线,单词之间用_分割;
- 如:mypackage,my_package
# 2、模块命名 mymodule.py,module_name.py
- 小写字母;
- 可使用下划线,单词之间用_分割;
- 如:mymodule.py,ad_stats.py
# 3、类命名 MyClass,ClassName
- 单词首字母大写;
- 如:AdStats,ConfigUtil,MyClass
- 内部类:可以使用额外的前导下划线****;
- 如:__MyClass
- **基类:**使用Base或Abstract前缀,如:CamelBase
# 4、函数命名
# 1)普通函数 myfunction(),my_function_name()
- 小写字母;
- 可使用下划线,单词之间用_分割;
- 如:myfunction(),my_example_function(),get_name() ,count_number() ,ad_stat()
# 2)私有函数(外部访问会报错) __get_name()
- 以**__开头**(2个下划线)
- 小写字母;
- 可使用下划线,单词之间用_分割;
- 如:__get_name()
#
3)函数和方法的参数 parameter,function_parameter_name
- 使用 self 作为实例方法的第一个参数;
- 使用 cls 作为类方法的第一个参数;
- 如果函数的参数名称,和保留的关键字冲突,通常使用一个后缀下划线好于使用缩写或奇怪的拼写;
- 缺省值等号两边无空格;def func(self, user=None):
# 5、变量命名
# 变量定义
- **全局变量:**属于模块的属性,在模块内、所有函数外、在class外,这是全局变量;
- 局部变量:在函数内、在class的方法(构造、类方法、静态方法、实例方法)内(变量未加self修饰),这是局部变量
- 类变量:属于类的属性,在class内,且不在class的方法内,这是类变量
- 实例变量:属于对象的属性,在class的方法内,且使用self修饰的变量,这是实例变量
注意说明:
- 如果局部变量与全局变量同名,那么方法或者函数中将优先使用的是局部变量的值,而不是使用全局变量;
- global关键字,显式的引用全局变量;
需要指出的是:
- Python 也推荐使用驼峰式命名,那是在类名、Type 变量、异常 exception 名这些情况。
- 而在包名、模块名、方法名和普通变量名 等情况,则是推荐用蛇形命名(lower_case_with_underscores)
# 1)类变量(全局变量名) COLOR_WRITE,GLOBAL_VAR_NAME
- 大写字母;
- 单词之间用_分割;
- 在java中相当于static静态变量;
- 如:NUMBER,COLOR_WRITE
# 2)常量 MAX_OVERFLOW,TOTAL
- 大写字母;
- 单词之间用_分割;
- 如:MAX_OVERFLOW,TOTAL
# 3)普通变量 this_is_a_var ,local_var_name
- 小写字母;
- 可使用下划线,单词之间用_分割;
- 如:this_is_a_var
# 4)实例变量 _instance_var
- 以**_开头**(1个下划线)
- 小写字母;
- 可使用下划线,单词之间用_分割;
- 如:_price ,_instance_var
# 5)私有实例变量(外部访问会报错) __private_var
- 以**__开头**(2个下划线)
- 小写字母;
- 可使用下划线,单词之间用_分割;
- 如:__price ,__private_var
# 6)专有变量 __class__
- __开头,__结尾;
- 一般为python的自有变量,开发不要以这种方式命名;
- 如:__doc__ ,__class__
# 6、异常命名 ExceptionNameError
- 以 Error 作为后缀;
# 7、缩写
- 命名应当尽量使用全拼写的单词;
- 常用的缩写,如XML、ID等,在命名时也应只大写首字母,如XmlParser
- 命名中含有长单词,对某个单词进行缩写,应使用约定成俗的缩写方式;
- 如:
- function 缩写为 fn
- text 缩写为 txt
- object 缩写为 obj
- count 缩写为 cnt
- number 缩写为 num
# 8、前导后缀下划线
Python 用下划线,作为变量前缀和后缀,指定特殊变量;
一个前导下划线:表示非公有,是私有的,如:_myprice ,_foo
- 在模块或类外不可以使用,只有类对象和子类对象自己能访问到这些变量;
- 不能直接访问的类属性,需通过类提供的接口进行访问;
- _xxx 不能用'from module import *'导入
一个后缀下划线:避免关键字冲突,如:count_
两个前导下划线:当命名一个类属性引起名称冲突时使用,也可能是私有成员,如:__name, __foo
- 只有类对象自己能访问,连子类对象也不能访问到这个数据;
- 类中的私有变量名
两个前导和后缀下划线:“魔”(有特殊用途)对象或者属性,如:__init__()代表类的构造函数,或者__file__
- 一般是系统定义名字,系统保留字命名法;
- 绝对不要创造这样的名字,而只是使用它们;
- 项目中可以使用这种命名,它的意义在于这种形式的变量是只读的,这种形式的类成员函数尽量不要重载;如:
- 其中 __id__、__parent__ 和 __message__ 都采用了系统保留字命名法;
def __init__(self, id, parent = None):
def __message__(self, msgid):
2
注意说明:
下划线,对解释器有特殊的意义,是内建标识符所使用的符号,建议程序员避免用下划线作为变量名的开始;
# 9、Python关键字
- 如果开发者尝试使用关键字作为变量名,Python 解释器会报错。
查看关键字:
输出结果:
['False', 'None', 'True', 'and', 'as', 'assert', 'async', 'await', 'break', 'class', 'continue', 'def', 'del', 'elif', 'else', 'except', 'finally', 'for', 'from', 'global', 'if', 'import', 'in', 'is', 'lambda', 'nonlocal', 'not', 'or', 'pass', 'raise', 'return', 'try', 'while', 'with', 'yield']
# 10、Python内置函数
- 如果开发者使用内置函数的名字作为变量名,Python 解释器倒不会报错,只是该内置函数就被这个变量覆盖了,该内置函数就不能使用了。
Python内置函数
abs() all() any() basestring() bin() bool() bytearray() callable() chr() classmethod() cmp() compile() complex() delattr() dict() dir() divmod() enumerate() eval() execfile() file() filter() float() format() frozenset() getattr() globals() hasattr() hash() help() hex() id() input() int() isinstance() issubclass() iter() len() list() locals() long() map() max() memoryview() min() next() object() oct() open() ord() pow() print() property() range() raw\_input() reduce() reload() repr() reversed() zip() round() set() setattr() slice() sorted() staticmethod() str() sum() super() tuple() type() unichr() unicode() vars() xrange() Zip() \_\_import\_\_() apply() buffer() coerce() intern
# 1、代码行长度
- 每行代码尽量不超过 80 个字符,在特殊情况下可以略微超过 80 ,但最长不得超过 120;
# 2、引号的使用
- 自然语言 使用双引号 “…” ,如:错误信息;很多情况还是 unicode,使用u"你好世界"
- 机器标识 使用单引号 ‘…’ ,如:dict 里的 key
- 正则表达式使用原生的双引号 r"…"
- 文档字符串 (docstring) 使用三个双引号"""文档字符串"""
# 3、空行的使用
# 1)模块中,函数,类定义之间,空2行
# 2)类成员函数之间,空1行
# 3)在二元运算符两边,各空一格 [=,-,+=,==,>,in,is not, and]
正确的写法
不推荐的写法
# 4)函数的参数列表中,逗号之后,要有空格
正确的写法
不推荐的写法
# 5)函数的参数列表中,默认值等号两边,不要添加空格
正确的写法
def complex(real, imag=0.0):
不推荐的写法
def complex(real, imag = 0.0):
# 6)左括号之后,右括号之前,不要加多余的空格
正确的写法
spam(ham[1], {eggs: 2})
不推荐的写法
spam( ham[1], { eggs : 2 } )
# 7)字典对象的左括号之前,不要多余的空格
正确的写法
dict['key'] = list[index]
不推荐的写法
dict ['key'] = list [index]
# 8)不要为对齐赋值语句,而使用额外空格
正确的写法
不推荐的写法
# 4、import 语句
# 1)单独import时,不要在一行导入多个;
正确的写法
不推荐的写法
import sys,os
# 2)from ... import可以在一行导入多个
正确的写法
from subprocess import Popen, PIPE
# 3)import语句应该使用 absolute import
正确的写法
from foo.bar import Bar
不推荐的写法
from …bar import Bar
# 4)import语句书写位置
import语句应该放在文件头部,置于模块说明及docstring之后,于全局变量之前;
import语句应该按照顺序排列,每组之间用一个空行分隔;
导入其他模块的类定义时,可以使用相对导入;
from myclass import MyClass
# 5)如果发生命名冲突,则可使用命名空间
# 5、换行
# 1)禁止复合语句,即一行中包含多个语句
正确的写法
不推荐的写法
do_first();do_second();do_third();
# 2)if/for/while一定要换行
正确的写法
不推荐的写法
if foo == 'blah': do_blash_thing()
# 3)支持括号内的换行
- 括号内的换行,第二行缩进到括号的起始处;
- 起始括号就换行,第二行缩进 4 个空格
# 4)使用反斜杠\换行,二元运算符+ .等应出现在行末
# 6、注释
# 1)块注释
- “#”号后空一格;
- 段落间用空行分开(同样需要“#”号)
# 2)行注释
- 至少使用两个空格和语句分开
mystr = 'hello'
# 3)文档注释(Docstring)
- 所有的公共模块、函数、类、方法,都应该写文档注释 docstring
- 私有方法不一定需要,但应该在 def 后提供一个块注释来说明。
docstring 的首行不换行, 如有多行,结束"""应该独占一行,除非此 docstring 只有一行。
文档注释,一般是放在自定义的模块/类/方法/函数的第一行,添加功能说明,可以使用.__doc__获取对应说明;
print(myfunction.__doc__)
输出结果:我的文档注释说明
不要在文档注释复制函数定义原型, 而是具体描述其具体内容, 解释具体参数和返回值等
"""function(a, b) -> list"""
对函数参数、返回值等的说明采用numpy标准, 如下所示
"""在这里写函数的一句话总结(如: 计算平均值). 示例使用doctest格式, 在`>>>`后的代码可以被文档测试工具作为测试用例自动运行 >>> print [x + 3 for x in a]
文档注释不要中英文混用,通常一两句话能把情况说清楚即可
模块、公有类、公有方法, 能写文档注释的, 应该尽量写文档注释
# 4)重要的注释
- 比较重要的注释段, 使用多个等号=隔开, 可以更加醒目, 突出重要性
# =====================================
# 请勿在此处添加 get post等app路由行为 !!!
# =====================================
2
3
# 7、模块
- 将相关的类和顶级函数,放在同一个模块里,不像Java, 没必要限制一个类一个模块;
# 10分钟了解代码命名规范(Java、Python) (opens new window)
# 类:
总是使用首字母大写单词串。如MyClass、ClassName。内部类可以使用额外的前导下划线。
# 函数和方法:
小写+下划线,如method_name。
# 函数参数:
小写+下划线,如function_parameter_name。如果一个函数的参数名称和保留的关键字冲突,通常使用一个后缀下划线,如random_。
# 全局变量:
对于from M import *导入语句,如果想阻止导入模块内的全局变量可以使用旧有的规范,在全局变量上加一个前导的下划线,如_var_name。应避免使用全局变量。
# 变量:
小写,由下划线连接各个单词。如color、this_is_a_variable。
注意:
- 不论是类成员变量还是全局变量,均不使用 m 或 g 前缀。
- 私有类成员使用单一下划线前缀标识。
- 变量名不应带有类型信息,因为Python是动态类型语言。如 iValue、names_list、dict_obj 等都是不好的命名。
# 常量:
常量名所有字母大写,由下划线连接各个单词如MAX_OVERFLOW,TOTAL。
# 异常:
以“Error”作为后缀。
# 文件名:
全小写,可使用下划线
# 包:
应该是简短的、小写的名字。如果下划线可以改善可读性可以加入,如mypackage。
# 模块:
与包的规范同,如mymodule。
# 缩写:
命名应当尽量使用全拼写的单词,缩写的情况有如下两种:
- 常用的缩写,如XML、ID等,在命名时也应只大写首字母,如XmlParser。
- 命名中含有长单词,对某个单词进行缩写。这时应使用约定成俗的缩写方式。
例如:
function 缩写为 fn
text 缩写为 txt
object 缩写为 obj
count 缩写为 cnt
number 缩写为 num,等。
# 前导后缀下划线:
一个前导下划线:表示非公有。
一个后缀下划线:避免关键字冲突。
两个前导下划线:当命名一个类属性引起名称冲突时使用。
两个前导和后缀下划线:“魔”(有特殊用图)对象或者属性,例如__init__或者__file__。绝对不要创造这样的名字,而只是使用它们。
注意:关于下划线的使用存在一些争议。
# 特定命名方式:
主要是指 xxx 形式的系统保留字命名法。项目中也可以使用这种命名,它的意义在于这种形式的变量是只读的,这种形式的类成员函数尽量不要重载。如
class Base(object):
def init(self, id, parent = None):
self.id = id
self.parent = parent
def message(self, msgid):
其中 id、parent 和 message 都采用了系统保留字命名法。