在类中创建方法属性

时间:2016-03-13 03:51:02

标签: python

我可以创建以下格式的函数。

def bar():
    if not hasattr(bar, 'c'):
        bar.c = 0
    bar.c += 1
    return bar.c

运行时,按预期产生以下输出:

>>> bar()
1
>>> bar()
2
>>> bar()
3

但是如果我突然将这个函数移到一个类中,Python会给我一个错误。

class Foo(object):

    def bar(self):
        if not hasattr(self.bar, 'c'):
            self.bar.c = 0
        self.bar.c += 1
        return self.bar.c

现在我

>>> foo = Foo()
>>> foo.bar()
...
AttributeError: 'method' object has no attribute 'c'

它告诉我它没有属性,但我试图创建属性。这里发生了什么?

1 个答案:

答案 0 :(得分:5)

取自python文档(https://docs.python.org/2/library/stdtypes.html?highlight=instancemethod)“但是,由于方法属性实际存储在底层函数对象(meth.im_func)中,因此不允许在绑定或未绑定方法上设置方法属性。” p>

换句话说,我们可以尝试Foo.bar.im_func.c = 0,但不幸的是,它是只读的,所以它不起作用。

因此,对于你想要完成的事情,我建议

class Foo(object):
  c = 0
  def bar(self):
    Foo.c += 1
    return Foo.c

f = Foo()
print f.bar()
print f.bar()
print f.bar()

适用于python2和python3。

唯一的“缺点”是c可用于类Foo的任何其他方法。