相似的函数:
__setattr__
__hasattr__
__delattr__
__getattr__
__getattribute__
__setitem__
__getitem__
__delitem__
__setattr__
和___setitem__
的区别
关于这一点,需要读者有一点基础。
实例.属性调用“attr”
实例[属性]调用“item”
get,set,del的用法
- get:当实例以及类中调用皆无此属性时调用
- set:设置属性时调用
- del:删除属性时调用
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)
#__setattr__添加/修改属性会触发它的执行
f1=Foo(10)
print(f1.__dict__) # 因为你重写了__setattr__,凡是赋值操作都会触发它的运行,你啥都没写,就是根本没赋值,除非你直接操作属性字典,否则永远无法赋值
f1.z=3
print(f1.__dict__)
#__delattr__删除属性的时候会触发
f1.__dict__['a']=3#我们可以直接修改属性字典,来完成添加/修改属性的操作
del f1.a
print(f1.__dict__)
#__getattr__只有在使用点调用属性且属性不存在的时候才会触发
f1.xxxxxx
__getattr__
和__getattribute__
的区别
-
__getattribute__
有无此实例皆会调用 - 当
__getattribute__
抛出AttributeError
时,会调用__getattr__
网友评论