• __setattr__和__delattr__和__getattr__


    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)
    

    一、setattr

    • 添加/修改属性会触发它的执行
    print(f1.__dict__)  # 因为你重写了__setattr__,凡是赋值操作都会触发它的运行, 
    				   # 你啥都没写,就是根本没赋值,除非你直接操作属性字典,
        			   # 否则永远无法赋值
    f1.z = 3
    print(f1.__dict__)
    

    二、delattr

    • 删除属性的时候会触发
    f1.__dict__['a'] = 3  # 我们可以直接修改属性字典,来完成添加/修改属性的操作
    del f1.a
    print(f1.__dict__)
    
    ----> from delattr
    {}
    

    三、 getattr

    • 只有在使用点调用属性且属性不存在的时候才会触发
    f1.xxxxxx
    
    ----> from getattr:你找的属性不存在
    
  • 相关阅读:
    redis数据结构
    django内置密码原理
    生成图片验证码
    如何封装VUE的axios请求
    杭电1717小数化分数2
    杭电2504 又见GCD
    杭电 2136 Largest prime factor(最大素数因子的位置)
    Linux终端的一些快捷键命令
    杭电 1772 cake
    杭电ACM 1713 相遇周期
  • 原文地址:https://www.cnblogs.com/Dr-wei/p/11851079.html
Copyright © 2020-2023  润新知