使用setattr()设置特殊方法

时间:2012-05-07 14:57:32

标签: python introspection setattr

是否可以使用__getitem__动态地将特殊方法(例如setattr())分配给类实例?例如,如果我有这个:

class Example (object):
    pass

然后试试这个:

>>> example = Example()
>>> setattr(example, '__getitem__', lambda x: 1)

我明白了:

>>> example['something']
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
TypeError: 'Example' object has no attribute '__getitem__'

但当然这很好用:

>>> example.__getitem__('something')
1

这里显然有一些事情我不明白Python如何为这类事情进行方法查找。这些方法是否必须在上设置,而不是在实例上设置?

更新

所以,我应该明确表示我可以在Example类上看到这个......我希望有一种方法可以设置它们 per-instance ,但是到目前为止我所看到的共识是你做不到的。

2 个答案:

答案 0 :(得分:6)

这里的问题是__getitem__()是在类级别定义的,而不是在实例级别定义的:

>>> class Example (object):
...     pass
... 
>>> example = Example()
>>> setattr(Example, '__getitem__', lambda x, y: 1)
>>> example['something']
1

如果您需要它是特定于实例的:

>>> class Example(object):
...     def __getitem__(self, item):
...         return self._getitem(item)
... 
>>> example = Example()
>>> setattr(example, '_getitem', lambda x: 1)
>>> example['something']
1
>>> example2 = Example()
>>> setattr(example2, '_getitem', lambda x: 2)
>>> example['something']
1
>>> example2['something']
2

答案 1 :(得分:0)

您是否尝试过monkeypatching类,而不是实例?

>>> example = Example()
>>> setattr(Example, '__getitem__', lambda self,x: 1)