python - 覆盖 __init__ 中参数的类型提示

标签 python pycharm overriding

关于这段代码:

class Obj():
    def a(self):
        pass


class ObjChild(Obj):
    def b(self):
        pass


class A:
    def __init__(self, obj: Obj):
        self.obj = obj


class B(A):
    def __init__(self, obj: ObjChild):
        super().__init__(obj)
        
    def kuku(self):
        self.obj.b()

Pycharm 警告我最后一行:

Unresolved attribute reference 'b' for class 'Obj'

但我将 __init__ 中传递的 obj 类型提示为 ObjChild,因此它应该静态地知道 self.obj 是一个 ObjChild 实例,并且有 b 方法。

我怎样才能让 Pycharm 意识到这一点?它打乱了我在项目中的自动完成。

最佳答案

使 A 成为 Generic:

from typing import Generic, TypeVar


class Obj:
    def a(self):
        pass


_Obj = TypeVar('_Obj', bound=Obj)


class ObjChild(Obj):
    def b(self):
        pass


class A(Generic[_Obj]):
    def __init__(self, obj: _Obj):
        self.obj = obj


class B(A[ObjChild]):
    def __init__(self, obj: ObjChild):
        super().__init__(obj)
        self.obj.b()

除非您将 A 设为泛型,否则将 ObjChild 传递给 A.__init__A.obj< 之间没有任何联系 是一个 ObjChild

关于python - 覆盖 __init__ 中参数的类型提示,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/70463616/

相关文章:

python - 抓取多个页面时经常出现 HTTP 错误 413

python - 如何将 STL、网格导入 Django views.py 或 models.py

intellij-idea - 如何在Pycharm/Intellij Idea中提交之前运行测试

java - 在不调用所需的初始化方法的情况下防止子类实例化的正确方法?

ruby - 我可以使用数学符号调用(调用)Ruby 阶乘方法吗?

java - 如何在 Java 中使用匿名类重载方法?

python - hombrew 升级后 pip3 消失了

python - 如何在同一个应用程序中拥有两个登录/身份验证策略?

javascript - PyCharm 中的 JSX/Babel 高亮显示

django - 每次更改代码后我是否需要重新启动apache