【发布时间】:2020-01-25 02:37:18
【问题描述】:
在深入研究之前,我的问题是:如何在子类中使用类型提示来指定实例属性的不同类型?
如果您不清楚这意味着什么,请阅读下文,我已在其中起草了一个示例来澄清问题。
完整说明
我有一个抽象类 Foo,以及一个名为 SubclassOfFoo 的 Foo 的子类。
Foo 有一个抽象方法get_something,它返回一个Something 类型的对象。
Something 有一个名为SubclassOfSomething 的子类。 SubclassOfSomething 有一个额外的方法something_special。
SubclassOfFoo 覆盖 get_something 以返回 SubclassOfSomething 类型的对象。然后,SubclassOfFoo 尝试使用SubclassOfSomething 的方法something_special。
但是,目前我的 PyCharm 的检查报告为 Unresolved attribute reference 'something_special' for class 'Something'。我正在尝试找出解决此问题的正确方法。
这一切都非常令人困惑,所以我编写了一个很好的小代码 sn-p 来帮助这里:
from abc import ABC, abstractmethod
class Something:
def __init__(self):
self.attr = 0
class SubclassOfSomething(Something):
def __init__(self):
Something.__init__(self)
def something_special(self):
self.attr = 1
class Foo(ABC):
def __init__(self):
self.my_class = self.get_something()
@abstractmethod
def get_something(self) -> Something:
pass
class SubclassOfFoo(Foo):
def __init__(self):
Foo.__init__(self)
def get_something(self) -> SubclassOfSomething:
return SubclassOfSomething()
def do_something_special(self):
self.my_class.something_special()
基本上,为了让一切顺利进行,我可以做以下几件事之一:
- 删除
get_something在Foo内返回的类型提示 - 在
SubclassOfFoo中为self.my_class使用类型提示来清除问题 - 使用泛型?
选项 1. 是我想要避免的
选项 2. 还不错,但我想不通
选项 3. 也是一个选项。
我也愿意接受其他选择,因为我确信有更好的方法。
您能帮我找出正确的处理方法吗?
我的尝试
为了模拟选项 2,我尝试使用 typing.Type,如下所示:Subclass in type hinting
但是,这对我不起作用。
【问题讨论】:
-
@101arrowz:该类型提示存在是因为更具体的返回类型信息很重要。不能假定
Something的任意实例具有something_special方法。 -
我怀疑最好的选择是使
Foo通用。
标签: python pycharm subclass type-hinting typing