python中的__dict__,__getattr__,__setattr__

python class 通过内置成员__dict__ 存储成员信息(字典)
我们可以通过重载__getattr__和__setattr__来拦截对成员的访问或者作出一些自己希望的行为
getattr 在访问对象访问类中不存在的成员时会自动调用,白话讲就是*.属性且属性不存在时调用,
setattr 方法用于在初始化对象属性或者修改对象属性的时候调用,即在类名.属性=值的时候就会调用__setattr__方法。
如 *.key = value 时调用。
具体看下面的例子

class A():
    def __init__(self, ax, bx):
        self.a = ax
        self.b = bx
    def f(self):
        print(self.__dict__)
    def __getattr__(self, name):
        print("__getattr__", name)
    def __setattr__(self, name, value):
        print("__setattr__", name, value)
        self.__dict__[name] = value
a = A(1, 2)
a.f()
a.x
a.x = 3
a.f()

输出结果

__setattr__ a 1
__setattr__ b 2
{'a': 1, 'b': 2}
__getattr__ x
__setattr__ x 3
{'a': 1, 'b': 2, 'x': 3}

分析:

a = A(1, 2)的时候执行了__init__函数,
self.a = ax 执行了 __setattr__函数 往内置__dict__字典里面写入了a:1
因此输出了结果 setattr a 1
self.b = bx 执行了 setattr__函数 往内置__dict__字典里面写入了b:2
因此输出了结果 setattr b 2
a.f()
显示__dict__字典信息。
显示结果 {‘a’: 1, ‘b’: 2}
a.x 因为x不在字典内,所以调用__getattr
,显示 getattr x
a.x = 3 这里调用了__setattr__函数 往内置__dict__字典里面写入了x:3
所以显示结果:setattr x 3
a.f() 再次查询__dict__字典信息,显示结果:{‘a’: 1, ‘b’: 2, ‘x’: 3}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在提供的代码,`__setattr__`方法被重写为`dict.__setitem__`,这意味着当我们给对象的属性赋值时,实际上是调用了`dict.__setitem__`方法来设置字典的键值对。这样做的目的是为了让对象支持通过点操作符来设置属性,使得对象可以像访问属性一样访问字典的键值对。这种做法在某些情况下可以提供更直观和方便的使用方式。 除了`__setattr__`方法外,还有`__getattr__`和`__delattr__`方法。`__getattr__`方法被重写为`dict.get`方法,当属性不存在时,会返回None,而不是抛出AttributeError异常。`__setattr__`方法被重写为`dict.__setitem__`,用于设置属性值。`__delattr__`方法被重写为`dict.__delitem__`,用于删除属性。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [python对象和字典dict的相互转化【点.和[属性]】的访问区别及特殊方法名总结](https://blog.csdn.net/weixin_43343144/article/details/92764884)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [Python字典转对象的两种方法(dict -> object使属性用点来调用)](https://blog.csdn.net/qq_21567385/article/details/107990864)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [python内置函数__getattr__、__serattr__、__delattr__与字典dict的使用](https://blog.csdn.net/SL1029_/article/details/129638430)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值