使用python 3.7,我在元类中创建了一个类属性。我希望能够通过类本身或该类的实例化对象访问属性。我可以通过创建一个类属性和一个实例属性来模拟它,但是它与PyCharm的类型提示紧密相关。这是我认为理想的设置:

class Meta(type):
    @property
    def cls_prop(cls) -> str:
        return 'foo'


class A(metaclass=Meta):
    pass


但不幸的是,结果如下:

>>> A.cls_prop
'foo'
>>> a = A()
>>> a.cls_prop
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
AttributeError: 'A' object has no attribute 'cls_prop'


在运行时可以在A中添加实例属性以调用class属性,但是PyCharm的类型自省会引起混淆(它开始将A.cls_prop视为property而不是str):

class A(metaclass=Meta):
  @property
  def cls_prop(self) -> str:
      return self.__class__.cls_prop

>>> A.cls_prop
'foo'
>>> a = A()
>>> a.cls_prop
'foo'


有一个更好的方法吗?

最佳答案

我认为使用父类可以更好地完成您想做的事情:

class Parent:
    @property
    def cls_prop(self):
        return 'foo'

class A(Parent):
    pass

>>> a = A()
>>> a.cls_prop
'foo'
>>>> A.cls_prop
<property object at 0x7f1afcb190e8>


如果您还希望能够直接在类上访问A.cls_prop(即不创建实例),则可能需要查看另一个问题:@staticmethod with @property

10-04 21:57
查看更多