首页 > 编程问答 >在类型提示中使用 Type[class_name] 而不是仅使用 class_name 时,python 未解析的属性引用

在类型提示中使用 Type[class_name] 而不是仅使用 class_name 时,python 未解析的属性引用

时间:2024-07-24 14:18:15浏览次数:9  
标签:python inheritance python-typing

我想输入提示继承结构,但我不知道如何正确执行。这个想法是函数 c 可以采用 A 的任何子类。一些子类具有其他子类没有的属性,并且这些属性不是在父类中定义,而是在子类中定义。函数 c 检查子类,如果它是正确的,则使用该类的特定属性。在此设置中,PyCharm 抱怨该参数不在父类中。

from abc import ABC
from typing import Type


class A(ABC):
    def __init__(self, a):
        self.a = a


class B(A):
    def __init__(self, a):
        super(B, self).__init__(a=a)
        self.b = a + 1


class D(A):
    def __init__(self, a):
        super(D, self).__init__(a=a)
        self.d = a - 1


def c(arg: Type[A]):
    if type(arg) is B:
        print(arg.b)
    if type(arg) is D:
        print(arg.d)

给出“未解析的 A 类属性引用‘b’”。有什么建议吗? 非常感谢!

令我更加好奇的是,下面的内容也抱怨 arg.a。当我在提示中使用 Type[A] 而不是 A 时。

def c(arg: Type[A]):
    if type(arg) is B:
        print(arg.b)
    if type(arg) is D:
        print(arg.d)
    print(arg.a)

遇到的问题是将类型提示与实例属性混淆了。当使用 Type[A] 时,是在说该参数应该是类 A 本身或其子类,而不是 A 的实例。

以下是解决此问题的两种方法:

1. 使用 isinstance 和类型检查:

from abc import ABC
from typing import Type

class A(ABC):
    def __init__(self, a):
        self.a = a

class B(A):
    def __init__(self, a):
        super(B, self).__init__(a=a)
        self.b = a + 1

class D(A):
    def __init__(self, a):
        super(D, self).__init__(a=a)
        self.d = a - 1

def c(arg: A):
    if isinstance(arg, B):
        print(arg.b)  # 现在可以访问 arg.b
    if isinstance(arg, D):
        print(arg.d)  # 现在可以访问 arg.d
    print(arg.a)  # 可以访问 arg.a,因为它在父类 A 中定义

在这个版本中,我们将 arg: Type[A] 更改为 arg: A ,这意味着我们期望 A 的一个实例。然后,我们使用 isinstance(arg, B) isinstance(arg, D) 来检查 arg 的实际类型,并在确定类型后访问相应的属性。

2. 使用类型提示和类型守卫:

from abc import ABC
from typing import Type

class A(ABC):
    def __init__(self, a):
        self.a = a

class B(A):
    def __init__(self, a):
        super(B, self).__init__(a=a)
        self.b = a + 1

class D(A):
    def __init__(self, a):
        super(D, self).__init__(a=a)
        self.d = a - 1

def c(arg: A):
    if isinstance(arg, B):
        print(arg.b)  # 现在可以访问 arg.b
    elif isinstance(arg, D):
        print(arg.d)  # 现在可以访问 arg.d
    print(arg.a)  # 可以访问 arg.a,因为它在父类 A 中定义

在这个版本中,我们使用 isinstance 检查类型,并在每个 if 语句块中创建了一个类型守卫。类型守卫告诉 MyPy 在该块中 arg 的类型是什么,从而允许我们访问正确的属性。

这两种方法都可以解决的问题,并使的代码更易于理解和维护。建议选择最适合的编码风格和项目需求的方法。

标签:python,inheritance,python-typing
From: 61457513

相关文章

  • python的包管理
    获取现有项目有那些依赖安装pipreqspipinstallpipreqs在项目根目录执行pipreqs.--encoding=utf8--force--pypi-server=http://mirrors.aliyun.com/pypi/simple/根据生成文件安装依赖pipinstall-rrequriements.txtpipreqs命令选项Options:--use-local......
  • 如何在 python selenium 中禁用广告隐私设置?
    我对上面有一些问题。当然,当我尝试绕过cloudflare验证码时,我的策略已经破坏了任何cloudflare。但有一些问题。当我在pythonselenium中打开新选项卡时,会弹出广告隐私窗口。谁有解决这个问题的经验。谢谢您的帮助。一旦通过,就不会再发生了。我理解你想在......
  • [附开题]flask框架的基于微信小程序的医院远程预约挂号系统设计与实现6ky98(python+源
    本系统(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。系统程序文件列表开题报告内容研究背景随着医疗需求的日益增长和互联网技术的飞速发展,传统的医院挂号方式已难以满足患者高效、便捷的就医需求。患者往往需要长时间排队等待挂号......
  • [附开题]flask框架的基于用户行为分析的商品推荐系统APP1qut6APP(python+源码)
    本系统(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。系统程序文件列表开题报告内容研究背景在移动互联网时代,电子商务平台的竞争日益激烈,如何精准地推荐商品给用户,提升用户体验与购买转化率,成为电商企业关注的焦点。传统的推荐算法......
  • [附开题]flask框架的教务管理系统q6190(源码+论文+python)
    本系统(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。系统程序文件列表开题报告内容研究背景随着信息技术的飞速发展和教育改革的不断深入,教务管理工作日益复杂且重要。传统的手工管理方式已难以满足当前高校教务管理的需求,特别是在......
  • python闭包和装饰器
    一、闭包1.闭包的三要素1.外部函数嵌套内部函数2.内部函数可以调用外部函数的局部变量3.外部函数返回内部函数2.示例代码 #外部函数deffunc1():print("func1")#内部函数deffunc2():print("func2")#外部函数返回内部函数re......
  • python Subprocess 模块
    Subprocess介绍subprocess模块是Python标准库中的一个模块,用于管理子进程(子程序)。通过subprocess模块,可以在Python脚本中启动新的进程、连接到它们的输入/输出流以及获取它们的返回值。Subprocess主要功能1.执行外部命令:subprocess允许你在Python脚本中执行系统命......
  • Python 类型提示:自引用类型检查
    我认为静态类型确实会让我在Python中的生活更轻松,考虑到我通常使用C语言工作。我创建了一个像这样的类:classnode(object):"""properties,constructor,etc."""defadd_outneighbor(self,neighbor:node)->None:"""d......
  • Python用shp文件裁剪多个遥感影像的方法
      本文介绍基于Python中ArcPy模块,基于矢量数据范围,对大量栅格遥感影像加以批量裁剪掩膜的方法。  首先,话不多说,本文所需要的代码如下所示。#-*-coding:utf-8-*-"""CreatedonTueDec1320:07:482022@author:fkxxgis"""importarcpyfromarcpy.saimport*......
  • 以编程方式删除 Python 源中的类型提示
    我有一些为Python3.5编写的源代码,我想使其在Python3.4下可执行。我使用的3.5中唯一在3.4中不可用的功能是类型提示,因此我想编写一个脚本来完全删除这些功能。乍一看这似乎很容易,我决定编写一些正则表达式这样做,但后来我想到了一些边缘情况,我不确定如何解决像这样的......