Python的代码风格由PEP 8描述,这个文档描述了Python编程风格的方方面面。在遵守这个文档的条件下,不同程序员编写的Python代码可以保持最大程度的相似风格。这样就易于阅读,易于在成员之间交流。
通常情况下,单下划线_会在以下3种场景中使用:
1.1 在解释器中,
这种情况下,‘_’代表交互式解释器会话中上一条执行的语句的结果。这种用法首先被标准CPython解释器采用,然后其他类型的解释器也先后采用。
1.2 作为一个名称,
‘_’ 作为临时性的名称使用。这样,当其他人阅读你的代码时将会知道,你分配了一个特定的名称,但是并不会在后面再次用到该名称。例如,下面的例子中,你可能对循环计数的实际值并不感兴趣,此时就可以使用'_'。
1.3 国际化,
也许你曾看到'_'会被作为一个函数来使用。这种情况下,它通常用于实现国际化和本地化字符串之间翻译查找的函数名称,这似乎源自并遵循相应的C约定。
1. 变量
1.1 _xxx
单下划线开头的变量,表明这是一个受保护(protected)的变量,原则上不允许直接访问,但是外部类还是可以访问到这个变量。因为这只是一个程序员之间的约定,用于警告说明这是一个受保护的变量,外部类不要去访问它。
以单下划线'_'为前缀的名称,如_xxx,应该被视为API中非公开的部分(不管是函数,方法还是数据成员)。此时,应该将它们看做一种实现细节,在修改他们时无需对外部通知。
正如上面所说,这确实类似一种惯例,因为它对解释器来说确实有一定的意义,如果你写了代码‘from <模块/包名> import *’,那么以''开头的名称都不会被导入,除非模块或包中的'_all'列表显示地包含了它们。不过值得注意的是,如果使用import a_module这样导入模块,仍然可以用a_module._some_var这样的形式访问到这样的对象。
1.2 _ _xxx
双下划线开头的,表示的是私有类型(private)的变量,只能允许这个类本身进行访问,甚至它的子类也不可以,用于命名一个类属性(类变量),调用时名字会被改变(在类Student内部,name会变成_studentname,如self._Student__name)。双下划线开头的实例变量是不是一定不能从外部访问呢?其实也不是,仍然可以通过_Student__name来访问__name变量:
1.3 _ _xxx_ _
以双下划线开头,并且以双下划线结尾的,是内置变量,内置变量是可以直接访问的,如init,__import__或是file。所以,不要自己定义这类变量。
1.4 xxx_
单下划线结尾的变量一般只是为了避免与Python关键字的命名冲突。
1.5
USER_CONSTANT,大写加下划线,对于不会发生改变的全局变量,使用大写加下划线。
2. 函数和方法
总体而言应该使用,小写和下划线。但有些比较老的库使用的是混合大小写,即首单词小写,之后每个单词第一个字母大写,其余小写。但现在,小写和下划线已经成为规范。
2.1 受保护方法:小写和一个前导下划线,
这里和受保护变量一样,并不是真正的受保护权限。同时也应该注意一般函数不要使用两个前导下划线(当遇到两个前导下划线时,Python的名称改编特性将发挥作用)。特殊函数后面会提及。
2.2 特殊方法:小写和两个前导下划线,两个后置下划线。
这种风格只应用于特殊函数,比如操作符重载等。对Python系统来说,这将确保不会与用户自定义的名称冲突。通常,你将会覆写这些方法,并在里面实现你所需要的功能,以便Python调用它们。例如,当定义一个类时,你经常会覆写'init'方法。
2.3 函数参数:小写和下划线,缺省值等号两边无空格。
从测试结果看,即使有空格也无任何影响,所以倾向这是一个约定。
3. 类
类总是使用驼峰式命名,即所有单词首字母大写其余字母小写。类名应该简写,精确,并足以从中理解类所完成的工作。
4. 模块和包
除了特殊模块init之外,模块名称都是用不带下划线的小写字母。若是实现了一个协议,那么通常使用lib作为后缀。例如,
import smtplib
import os
转载:
- http://www.cnblogs.com/elie/p/5902995.html
- https://my.oschina.net/leejun2005/blog/387136utm_source=tuicool&utm_medium=referral