Chinaunix首页 | 论坛 | 博客
  • 博客访问: 149416
  • 博文数量: 35
  • 博客积分: 2386
  • 博客等级: 大尉
  • 技术积分: 380
  • 用 户 组: 普通用户
  • 注册时间: 2009-05-05 06:11
文章分类

全部博文(35)

文章存档

2011年(1)

2010年(2)

2009年(32)

分类: Python/Ruby

2009-08-15 20:33:17

参考 <>、<>


  访问字典的元素使用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 
阅读(9097) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~