首页 > 编程问答 >Python 3.6 中的相互递归类型,使用命名元组语法

Python 3.6 中的相互递归类型,使用命名元组语法

时间:2024-07-31 07:17:50浏览次数:15  
标签:python python-typing

我正在尝试实现图的节点和边。这是我的代码:

from typing import NamedTuple, List

class Node(NamedTuple):
    name: str
    edges: List[Edge]

class Edge(NamedTuple):
    src: Node
    dest: Node

这会引发错误,因为创建 Edge 时未定义 Node 类型。

NameError: name 'Edge' is not defined

切换定义不起作用,因为 Edge 也引用 Node

我怎样才能让它发挥作用?


你遇到的问题是 Python 中类定义的常见问题,而不仅仅是类型提示或命名元组。你无法以相互依赖的方式定义 Node Edge ,因为一个类的定义在另一个类的定义完成之前不可用。

你可以使用 Python 3.7+ 中的 typing.ForwardRef 来解决这个问题:

from typing import NamedTuple, List, ForwardRef

class Edge(NamedTuple):
    src: 'Node'
    dest: 'Node'

class Node(NamedTuple):
    name: str
    edges: List[Edge]

这告诉 Python 解释器 'Node' Edge 的定义中是一个对稍后将定义的类的“前向引用”。

对于 Python 3.6, typing.ForwardRef 不可用。 作为一种解决方法,你可以使用字符串文字作为对尚未定义的类的注释:

from typing import NamedTuple, List

class Node(NamedTuple):
    name: str
    edges: List['Edge']  # 使用字符串文字 'Edge'

class Edge(NamedTuple):
    src: 'Node'  # 使用字符串文字 'Node'
    dest: 'Node'

虽然这在 Python 3.6 中有效,但建议尽可能使用 Python 3.7+ 并使用 typing.ForwardRef 来获得更清晰和更易读的代码。

标签:python,python-typing
From: 41862828

相关文章

  • 使用 keras 模型对函数进行 Python 类型提示
    如果我创建这样的函数:defmdl(input_shape):model=Sequential()model.add(Conv2D(depth=64,kernel_size=(3,3),input_shape=input_shape,activation='relu'))model.add(Dense(32),activation='relu')model.add(Dropout(0.3))m......
  • Python:自动完成可以用于列表中的元素吗?
    Python在函数参数和函数返回类型中具有类型提示。类的元素是否有类似的东西?我希望能够在如下示例中使用自动完成功能:classMyClass:defhello(self):print("Hello")mylist=[]mylist.append(MyClass())foriinmylist:i.hello()#Noautocomplete......
  • python 中 COM 对象的正确类型提示是什么?
    我在python中使用COM对象来向3rd方软件公开可编程接口。这是通过使用Dispatchfromwin32com.client来实现的。我的项目也一直在使用python.3.7中的类型提示,但是我不确定如何为了类型提示的目的定义这些COM对象的类型。这个问题涉及我拥有的所有COM......
  • 如何遍历Python字典同时避免KeyErrors?
    解析大型JSON时,某些键可能仅在某些情况下存在,例如出现错误时。从服务器的API获取200OK的情况并不少见,但是您得到的响应包含应检查的错误。处理此问题的最佳方法是什么?我知道使用类似||之类的东西。|是处理KeyError的一种方法。get()但是如果......
  • Python 中的递归数据类型
    Python中最接近Haskell中的递归数据类型的是什么?(即在定义自身时使用类型自己的定义。)编辑:为了给出递归类型的更具体定义,下面是Haskell中的二叉树:dataTreea=Leafa|Branch(Treea)(Treea)我的阅读方式如下:二叉树可以是叶子,也可以包含两......
  • 如何在Python中平滑相邻的多边形?
    我正在寻找一种平滑多边形的方法,以便相邻/接触的多边形保持接触。单个多边形可以轻松平滑,例如使用PAEK或Bezier插值(https://pro.arcgis.com/en/pro-app/latest/tool-reference/cartography/smooth-polygon.htm),这自然会改变它们的边界边缘。但是如何平滑所有多边形......
  • Python多处理池不启动多个进程
    我正在尝试使用多处理池来创建多个进程。我有一个工作函数dummy_proc定义如下:importrefrommultiprocessingimportPooldefregex_check(input_string):#Patterntomatchboth"pm_lat"and"pm_lon_coslat"followedbytwofloatspattern=r"(c......
  • 迟滞建模作为 Python GEKKO 中 MPC 的控制约束
    我试图使用PythonGEKKO在用于控制信号调度的MPC优化问题中引入滞后约束。这已成为一项艰巨的任务,因为我无法将以下问题转换为GEKKO理解的方程。问题:如果开启时间<最短开启时间,则给定资产的控制调度不应将其关闭。如果关闭时间<最小关闭时间......
  • 在 Lambda Python 中获取 errorMessage": "期望值: 第 1 行第 1 列 (char 0)"
    我正在尝试使用slackapi和awslambda函数创建一个slack机器人。现在我只希望每当用户说“你好”时它就响应“你好”。当我在Lambda代码编辑器中测试代码时,出现此错误。我对Lambda很陌生,并且已经被困在这个问题上有一段时间了。非常感谢任何帮助!完整错误:Response......
  • 具有 Python lambda 函数的 QTimer 使用先前的数据运行
    我有一个GUI项目,它使用PySide2和Python3.8,它在QThread中执行一些后台任务。在该QThread中,我有QTimer成员对象,该对象必须定期运行一个函数,每次向其传递不同的数据。我没有使用QTimer.singleShot静态函数,因为如果需要某些特定场景,我需要......