Python中定义常量
时间:2009-08-15 来源:openspace
参考 <<Python Cookbook>>、<<Dive into Python>>
I 访问字典的元素使用dobj.get('key', somethingelse),如果对应key值元素不存在,你将会得到somethingelse值,例如“not found”
不要使用dobj['key'],因为如果key对应元素不存在,则会产生KeyError异常,这样必须使用try...except来封装
II 名字空间中的属性可以通过字典__dict__来访问
__setattr__负责处理属性赋值,其内进行赋值时要使用self.__dict__[attr] = value以防止递归
III sys.modules是一个字典,它包含了从Python开始运行起,被导入的所有模块。键字就是模块名,键值就是模块对象。请注意除了你的程序导入的模块外还有其它模块。Python在启动时预先装入了一些模块,如果你在一个Python IDE环境下,sys.modules包含了你在IDE中运行的所有程序所导入的所有模块
======================================================================
定义
class _const(object):
class ConstError(TypeError): pass
def __setattr__(self, name, value):
if self.__dict__.has_key(name):
raise self.ConstError, "Can't rebind const(%s)" % name
self.__dict__[name] = value
def __delattr__(self, name):
if name in self.__dict__:
raise self.ConstError, "Can't unbind const(%s)" % name
raise NameError, name
import sys
sys.modules[__name__] = _const()
使用
import const
const.value = somevalue
const.value = newvalue # 产生异常const.ConstError
======================================================================
技巧
1) 使用__setattr__来控制重新绑定
2) sys.modules['name']得到的是模块对象,通过模块对象可以访问其模块属性;而Python不会进行严格的类型检测,所以直接将一个_const类对象加入sys.modules字典,而__name__的值为对应模块const的名字'const',通过sys.modules[__name__] = _const()用类对象替换模块对象,将对应的名字空间加以限制
当使用import const时,会发生sys.modules['const'] = _const();而访问const.attrvalue时会发生sys.modules['const'].attrvalue,即_const().attrvalue
I 访问字典的元素使用dobj.get('key', somethingelse),如果对应key值元素不存在,你将会得到somethingelse值,例如“not found”
不要使用dobj['key'],因为如果key对应元素不存在,则会产生KeyError异常,这样必须使用try...except来封装
II 名字空间中的属性可以通过字典__dict__来访问
__setattr__负责处理属性赋值,其内进行赋值时要使用self.__dict__[attr] = value以防止递归
III sys.modules是一个字典,它包含了从Python开始运行起,被导入的所有模块。键字就是模块名,键值就是模块对象。请注意除了你的程序导入的模块外还有其它模块。Python在启动时预先装入了一些模块,如果你在一个Python IDE环境下,sys.modules包含了你在IDE中运行的所有程序所导入的所有模块
======================================================================
定义
class _const(object):
class ConstError(TypeError): pass
def __setattr__(self, name, value):
if self.__dict__.has_key(name):
raise self.ConstError, "Can't rebind const(%s)" % name
self.__dict__[name] = value
def __delattr__(self, name):
if name in self.__dict__:
raise self.ConstError, "Can't unbind const(%s)" % name
raise NameError, name
import sys
sys.modules[__name__] = _const()
使用
import const
const.value = somevalue
const.value = newvalue # 产生异常const.ConstError
======================================================================
技巧
1) 使用__setattr__来控制重新绑定
2) sys.modules['name']得到的是模块对象,通过模块对象可以访问其模块属性;而Python不会进行严格的类型检测,所以直接将一个_const类对象加入sys.modules字典,而__name__的值为对应模块const的名字'const',通过sys.modules[__name__] = _const()用类对象替换模块对象,将对应的名字空间加以限制
当使用import const时,会发生sys.modules['const'] = _const();而访问const.attrvalue时会发生sys.modules['const'].attrvalue,即_const().attrvalue
相关阅读 更多 +