<!DOCTYPE html>
python几种不一样命名风格
html
python变量分为:
python
常量全局变量,使用大写加下划线。指定的变量表示一个常数值
git
BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(file)))
常量定义的是一组值,程序须要依赖的一组不变值,大多数就是配置文件名,最好的作法是将全部常量放到一个文件中,例如django的settings文件 github
SECRET_KEY = '(5hjjo=-=r1s43d+=yu(ay2vy_pe53ut0kzd5skzxa9@5#qf_x'
# SECURITY WARNING: don't run with debug turned on in production!
DEBUG = True
ALLOWED_HOSTS = []
# Application definition
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'helloapp',
]
也能够使用Configparser模块建立配置文件。这种没有上一种好。
一段很好的像标记的代码,能够给定一些是无标记属性等 web
OPTIONS={}
def register_option(name):
return OPTIONS.setdefault(name,1<<len(OPTIONS))#bin(len(OPTIONS))查看二进制数据
def has_option(options,name):
return bool(options&name)
#定义标签
BLUE=register_option('BLUE')
RED=register_option('RED')
YELLOW=register_option('YELLOW')
#设置标签
SET=BLUE|RED
#判断标签是否存在设置中
has_option(SET,BLUE)
has_option(SET,YELLOW)
对于可变的且能够经过导入自由访问的全局变量,若是它们须要被保护,那么应该使用下划线加小写字母变成私有变量。 sql
函数和方法尽可能使用小写加下划线,有些状况也使用混合大小写 django
对于私有方法和函数,一般是前缀两个下划线,这样在运行时会被解释器重命名,这样能够避免与任何子类冲突。举例说明 canvas
class Base(object):
def __secret(self):
print("don't tell")
def public(self):
self.__secret()
class Top(Base):
def __secret(self):
print("never say never")
print(dir(Base))
b=Base()
b._Base__secret()
print(dir(Top))
Top().public()
#输出
['_Base__secret',..., 'public']
don't tell
['_Base__secret', '_Top__secret', ..., 'public']
don't tell
这样就会重命名带有双下划线的函数和方法 ruby
特殊方法就是使用双下划线开始和结尾,常规的方法不该该使用这样的写法。
def __init__(self): pass def __add__(self): pass
参数都是用小写,有时能够加下划线
属性都是用小写或小写加下划线
类名使用驼峰法WjWj
模块一般都是小写,不带下划线,出了特殊的如init模块,若是模块是包的私有模块会使用前缀加一个下划线。包也是同样
is_life=True#是否活着
is_connected=True#是否链接
has_cache=True#是否有内存
users=['zhangsan','lisi']
我的地址用全称
persons_addresses={'zhangsan':'beijing','lisi':'shanghai'}
类的名称简明扼要
SQLEngine
BaseCookie
模块和包要小写,简短sqlite,sha1,若是是协议加lib后缀,urllib