Python的魔法函数系列 __getattrbute__和__getattr__,,#!/usr/bin


#!/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 Noneif __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 Noneif __name__ == "__main__":    cn = ClassName("Tom", info={"sex": "F"})    # 本身类里面没有sex这个属性,我们通过字典传递进去的,你可以使用 __getattr__ 魔法函数,其实它就是去 __dict__里面去找    # 让他可以访问字典。    print(cn.sex)    print(cn.__dict__)

技术分享图片

两次结果都是HELLO

Python的魔法函数系列 __getattrbute__和__getattr__

评论关闭