#!/usr/bin/env python # -*- coding: utf-8 -*- import sys __metaclass__ = type """ __getattr__ 和 __getattribute__ 的区别 """ class ClassName: def __init__(self, name, info={}): self.name = name self.info = info # def __getattribute__(self, item): # """ # 这个魔法函数也是针对属性的,但是它的特点是在__getattr__之前执行,而且无论你访问 # 的属性是不是存在都返回这个函数里面的返回值。也就是你访问什么属性都返回一样的东西。 # 所以这个方法尽量不要自己重写。 # :param item: # :return: # """ # return "HELLO" def __getattr__(self, item): """ 这个魔法函数式在你试图访问一个不存在的属性时调用的,如果没有这个魔法函数 访问不存在的属性程序会报错,但是如果有这个函数你就可以加入逻辑处理,比如 返回一个 None,或者打印一些提示内容,或者进行纠正,比如你的属性都是小写 对方访问一个大写的,你这里就可以自动转换等 :param item: :return: None 其实不加return默认也会返回None """ return self.info.get(item) # print("not found.", item) # return None if __name__ == "__main__": cn = ClassName("Tom", info={"sex": "F"}) # 本身类里面没有sex这个属性,我们通过字典传递进去的,你可以使用 __getattr__ 魔法函数,其实它就是去 __dict__里面去找 # 让他可以访问字典。 print(cn.sex) print(cn.__dict__)
如果我们把__getattribute__取消注释再次执行
#!/usr/bin/env python # -*- coding: utf-8 -*- import sys __metaclass__ = type """ __getattr__ 和 __getattribute__ 的区别 """ class ClassName: def __init__(self, name, info={}): self.name = name self.info = info def __getattribute__(self, item): """ 这个魔法函数也是针对属性的,但是它的特点是在__getattr__之前执行,而且无论你访问 的属性是不是存在都返回这个函数里面的返回值。也就是你访问什么属性都返回一样的东西。 所以这个方法尽量不要自己重写。 :param item: :return: """ return "HELLO" def __getattr__(self, item): """ 这个魔法函数式在你试图访问一个不存在的属性时调用的,如果没有这个魔法函数 访问不存在的属性程序会报错,但是如果有这个函数你就可以加入逻辑处理,比如 返回一个 None,或者打印一些提示内容,或者进行纠正,比如你的属性都是小写 对方访问一个大写的,你这里就可以自动转换等 :param item: :return: None 其实不加return默认也会返回None """ return self.info.get(item) # print("not found.", item) # return None if __name__ == "__main__": cn = ClassName("Tom", info={"sex": "F"}) # 本身类里面没有sex这个属性,我们通过字典传递进去的,你可以使用 __getattr__ 魔法函数,其实它就是去 __dict__里面去找 # 让他可以访问字典。 print(cn.sex) print(cn.__dict__)
两次结果都是HELLO