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

转载于:https://www.cnblogs.com/rexcheny/p/10125733.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值