Python的魔法函数系列 __getattrbute__和__getattr__

Posted 昀溪

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Python的魔法函数系列 __getattrbute__和__getattr__相关的知识,希望对你有一定的参考价值。

 
#!/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

以上是关于Python的魔法函数系列 __getattrbute__和__getattr__的主要内容,如果未能解决你的问题,请参考以下文章

python魔法函数之__getitem__

python进阶之内置函数和语法糖触发魔法方法

魔法函数

python魔法方法

python魔法方法

python 那些‘魔法函数’