python如何从类体

时间:2017-08-06 06:49:52

标签: python class subclass static-methods class-method

假设我有一个类,使用静态方法,并且我希望将类属性设置为此方法返回的值:

class A:
    @staticmethod
    def foo():
        return 12

     baz = foo()

但是这样做我得到一个错误:

Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
  File "<stdin>", line 5, in A
TypeError: 'staticmethod' object is not callable

我找到了解决这个问题的方法:

class A:
    class B:
        @staticmethod
        def foo():
            return 2
baz = B.foo()

但是,例如,如果我写:

class A:
    class B:
        @staticmethod
        def foo():
            return 2

    class C:
        baz = B.foo()

我也收到错误:

Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
  File "<stdin>", line 6, in A
  File "<stdin>", line 7, in C
NameError: name 'B' is not defined

有没有办法在声明它时从类中调用静态方法? 为什么第一和第三个代码示例不起作用,但第二个代码呢? python解释器如何处理这样的声明?

2 个答案:

答案 0 :(得分:2)

staticmethod是一个描述符。描述符公开__get__(instance, cls)方法,允许通过实例或类级别访问它。

现在,在您的情况下,您希望在类节中调用它。通常这是不可能的,因为实例和类都不可用。但是staticmethod在任何情况下都会忽略它们,因此您可以使用以下相当讨厌的方法来调用它。

class A:
    @staticmethod
    def foo():
        return 12

    baz = foo.__get__(None, object)()

然后

>>> A.baz
12

注意:object作为第二个参数传递的唯一原因是staticmethod坚持传递某种类作为第二个参数。

答案 1 :(得分:0)

这也是一种解决方法,但它可能会有所帮助。

class正文中,您无法引用正在创建的类。 OTOH类装饰器接收一个初始化类,因此它可以直接调用它的方法。

def add_baz(cls):
    cls.baz = cls.foo()
    return cls 

@add_baz
class A:
    @staticmethod
    def foo():
        return 12