如何注释多个返回值的类型?
- 2025-04-15 09:20:00
- admin 原创
- 35
问题描述:
如何使用类型提示来注释一个返回值Iterable
总是产生两个值 abool
和 a 的函数str
?提示Tuple[bool, str]
很接近,只是它将返回值类型限制为元组,而不是生成器或其他类型的可迭代对象。
我非常好奇,因为我想注释一个foo()
用于返回多个值的函数,如下所示:
always_a_bool, always_a_str = foo()
通常函数类似于foo()
执行类似操作return a, b
(返回一个元组),但我希望类型提示足够灵活,可以用生成器或列表或其他东西替换返回的元组。
解决方案 1:
您总是返回一个对象;使用return one, two
只是返回一个元组。
是的,-> Tuple[bool, str]
完全正确。
只有类型Tuple
允许你指定固定数量的元素,每个元素都有不同的类型。如果你的函数产生固定数量的返回值,那么你确实应该始终返回一个元组,尤其是当这些返回值是特定的、不同类型的时候。
其他序列类型预计会针对可变数量的元素使用一种typing.Sequence
类型规范,因此此处不适用。另请参阅列表和元组之间有什么区别?
元组是异构数据结构(即,其条目具有不同含义),而列表是同质序列。元组具有结构,列表具有顺序。
Python 的类型提示系统遵循这一理念,目前没有语法来指定固定长度且在特定位置包含特定类型的可迭代对象。
如果你必须指定任何可迭代对象都可以,那么你能做的最好的就是:
-> Iterable[Union[bool, str]]
此时,调用者可以接收任意顺序的布尔值和字符串,并且长度未知(介于 0 和无穷大之间)。
最后但同样重要的是,从 Python 3.9 开始,你可以使用
-> tuple[bool, str]
而不是; ,大多数标准库容器类型都已添加对-> Tuple[bool, str]
类型提示符号的支持(完整列表请参阅PEP 585)。实际上,从 Python 3.7 开始,您也可以使用此功能,前提是您在模块中使用编译器开关,并使用支持该语法的类型检查器。from __future__ import annotations
扫码咨询,免费领取项目管理大礼包!