__getattr__() 和 __getattribute__()

转自:http://my.oschina.net/letiantian/blog/175578

关于__getattr__

object.__getattr__(self, name)
    Called when an attribute lookup has not found the attribute in the usual places (i.e. it is not an instance attribute nor is it found in the class tree for self). name is the attribute name. This method should return the (computed) attribute value or raise an AttributeError exception.
    Note that if the attribute is found through the normal mechanism, __getattr__() is not called. 
(This is an intentional asymmetry between __getattr__() and __setattr__().) This is done both for efficiency reasons and because otherwise __getattr__() would have no way to access other attributes of the instance. Note that at least for instance variables, you can fake total control by not inserting any values in the instance attribute dictionary (but instead inserting them in another object). See the __getattribute__() method below for a way to actually get total control in new-style classes.

关于__get__getattribute__

object.__getattribute__(self, name)
Called unconditionally to implement attribute accesses for instances of the class. If the class also defines __getattr__(), the latter will not be called unless __getattribute__() either calls it explicitly or raises an AttributeError. This method should return the (computed) attribute value or raise an AttributeError exception. In order to avoid infinite recursion in this method, its implementation should always call the base class method with the same name to access any attributes it needs, for example, object.__getattribute__(self, name).

Note This method may still be bypassed when looking up special methods as the result of implicit invocation via language syntax or built-in functions.

例子:

__getattr__示例: 
class Test(object):
    def __init__(self,name):
        self.name = name
    def __getattr__(self, value):
        if value == 'address':
            return 'China'

if __name__=="__main__":
    test = Test('letian')
    print test.name
    print test.address
    test.address = 'Anhui'
    print test.address
运行结果: 
letian
China
Anhui
如果是调用了一个类中未定义的方法,则__getattr__也要返回一个方法,例如: 
class Test(object):
    def __init__(self,name):
        self.name = name
    def __getattr__(self, value):
        return len

if __name__=="__main__":
    test = Test('letian')
    print test.getlength('letian')
运行结果: 
6
__getattribute__示例: 
class Test(object):
    def __init__(self,name):
        self.name = name
    def __getattribute__(self, value):
        if value == 'address':
            return 'China'
        

if __name__=="__main__":
    test = Test('letian')
    print test.name
    print test.address
    test.address = 'Anhui'
    print test.address
运行结果: 
None
China
China

参考:

Data model:  http://docs.python.org/2/reference/datamodel.html  
Overwriting __getattr__ makes help(…) fail with TypeError: http://stackoverflow.com/questions/5157746/overwriting-getattr-makes-help-fail-with-typeerror  
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值