getattribute方法,Python属性访问拦截器的用法

__getattribute__()方法是属性访问时的拦截器,每当访问属性的时候,会先执行这个方法,然后再执行访问属性的操作步骤,可以用来记录属性访问的log。

简单说,想知道谁访问了你的某个变量,就用__getattribute__()方法

代码示例如下:

 

class Itcast(object):
    def __init__(self, subject1):
        self.subject1 = subject1
        self.subject2 = "haha"

    def __getattribute__(self, obj): #重写父类的__getattribute__方法,形参obj是访问的属性,是一个属性名字字符串

        print("*******>%s"%obj)
        if obj == "subject1":        #如果属性名是subject1,可以做一些操作
            print("log subject1")
            return "python"
        else:              #else必须写,如果不写,那subject2以及show方法就访问不到了
            temp = object.__getattribute__(self,obj)   #调用父类的__getattribute__方法
            print("------>%s"%str(temp))
            return temp      #不写return的话,show方法无法执行

    def show(self):
        print("this is Itcast")


s = Itcast("python")
print(s.subject1)
print(s.subject2)
s.show()             #show方法执行的时候也会先走属性拦截器方法

 

千万注意__getattribute__方法里面不能再使用self.的方式调用属性或者方法,因为你这样用,等于执行self.这句话的时候,又要先执行__getattribute__方法,执行这个方法的时候,执行到self.又开始执行__getattribute__方法,那你就死循环到这里了。

如果需要对某些属性进行记录log,可以按照参考下面的代码,修改print(item)为记录log的代码块

class D(object):
    def __init__(self):
        self.num = 0

    def __getattribute__(self, item):
        if item == "num":
            print(item)        #如果访问的属性名字叫num,则记录log
            temp = object.__getattribute__(self, item)   #调用父类方法把原来num的值返回去
            return temp
        else:
            temp = object.__getattribute__(self, item)
            return temp


a = D()
print(a.num)

 

posted @ 2019-12-17 13:45  白杨的博客  阅读(923)  评论(0编辑  收藏  举报