是否可以使用__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 ,但是到目前为止我所看到的共识是你做不到的。
答案 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)