一尘不染

在python中动态添加@property

python

我知道我可以通过执行以下操作来向对象动态添加实例方法:

import types
def my_method(self):
    # logic of method
# ...
# instance is some instance of some class
instance.my_method = types.MethodType(my_method, instance)

稍后我可以打电话给我instance.my_method(),自我将被正确绑定,一切正常。

现在,我的问题是:如何做完全相同的事情来获得用@property装饰新方法的行为?

我猜是这样的:

instance.my_method = types.MethodType(my_method, instance)
instance.my_method = property(instance.my_method)

但是,这样做会instance.my_method返回一个属性对象。


阅读 244

收藏
2020-12-20

共1个答案

一尘不染

property描述对象需要住 实例中
,有你想要的效果。如果您不想更改现有的类以避免更改其他实例的行为,则需要创建“每个实例的类”,例如:

def addprop(inst, name, method):
  cls = type(inst)
  if not hasattr(cls, '__perinstance'):
    cls = type(cls.__name__, (cls,), {})
    cls.__perinstance = True
    inst.__class__ = cls
  setattr(cls, name, property(method))

我用属性标记这些特殊的“每实例”类,以避免addprop在同一实例上进行多次调用时不必要地进行多个调用。

请注意,就像对的其他用法一样property,您需要游戏中的类是 新样式 (通常是通过直接继承或间接继承来获得object),
而不是 默认情况下分配给不包含以下内容的类的古老的旧样式(Python 3中已删除)基地。

2020-12-20