为覆盖 __getattribute__ 的 class 实现 __del__ 方法
Implement _del_ method for a class with __getattribute__ overriden
以this question为指针,假设存在如下class:
class Container(object):
def __init__(self, **kwargs):
self._meta = defaultdict(lambda: None)
for attr, value in kwargs.iteritems():
self._meta[attr] = value
def __getattr__(self, key):
try:
return self._meta[key]
except KeyError:
raise AttributeError(key)
def __setattr__(self, key, value):
if key in ('_meta', '_hasattr'):
super(Container, self).__setattr__(key, value)
else:
self._meta[key] = value
这允许以下行为:
c = Container()
c.a = 1
print(c.a) # 1
print(c.b) # None
问题:实现运算符的最佳方式是什么,以便以下工作:
# Should delete the value of a from Container._meta
del c.a
当然,显然可以实现一种方法,
def _delete(self, key):
...
但是有没有办法重新使用 python 运算符来做到这一点?
只需定义__delattr__
方法:
def __delattr__(self, key):
del self._meta[key]
以this question为指针,假设存在如下class:
class Container(object):
def __init__(self, **kwargs):
self._meta = defaultdict(lambda: None)
for attr, value in kwargs.iteritems():
self._meta[attr] = value
def __getattr__(self, key):
try:
return self._meta[key]
except KeyError:
raise AttributeError(key)
def __setattr__(self, key, value):
if key in ('_meta', '_hasattr'):
super(Container, self).__setattr__(key, value)
else:
self._meta[key] = value
这允许以下行为:
c = Container()
c.a = 1
print(c.a) # 1
print(c.b) # None
问题:实现运算符的最佳方式是什么,以便以下工作:
# Should delete the value of a from Container._meta
del c.a
当然,显然可以实现一种方法,
def _delete(self, key):
...
但是有没有办法重新使用 python 运算符来做到这一点?
只需定义__delattr__
方法:
def __delattr__(self, key):
del self._meta[key]