__setattr__和__delattr__和__getattr__

class Foo:
    x = 1

    def __init__(self, y):
        self.y = y

    def __getattr__(self, item):
        print('----> from getattr:你找的屬性不存在')

    def __setattr__(self, key, value):
        print('----> from setattr')
        # self.key = value  # 這就無限遞歸了,你好好想一想
        # self.__dict__[key] = value  # 應該使用它

    def __delattr__(self, item):
        print('----> from delattr')
        # del self.item  # 無限遞歸了
        self.__dict__.pop(item)


f1 = Foo(10)

1、__setattr__

  • 添加/修改屬性會觸發它的執行
print(f1.__dict__
      )  # 由於你重寫了__setattr__,凡是賦值操做都會觸發它的運行,你啥都沒寫,就是根本沒賦值,除非你直接操做屬性字典,不然永遠沒法賦值
f1.z = 3
print(f1.__dict__)

2、__delattr__

  • 刪除屬性的時候會觸發
f1.__dict__['a'] = 3  # 咱們能夠直接修改屬性字典,來完成添加/修改屬性的操做
del f1.a
print(f1.__dict__)
----> from delattr
{}

3、 __getattr__

  • 只有在使用點調用屬性且屬性不存在的時候纔會觸發
f1.xxxxxx
----> from getattr:你找的屬性不存在
相關文章
相關標籤/搜索