- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我被困在试图理解 TypeVar
的边界上当以两种不同的方式使用它时:
Enums = TypeVar("Enums", Enum1, Enum2)
Enums = TypeVar("Enums", bound=Union[Enum1, Enum2])
#!/usr/bin/env python3.6
"""Figuring out why enum is saying incompatible return type."""
from enum import IntEnum, EnumMeta
from typing import TypeVar, Union
class Enum1(IntEnum):
MEMBER1 = 1
MEMBER2 = 2
class Enum2(IntEnum):
MEMBER3 = 3
MEMBER4 = 4
# Enums = TypeVar("Enums", bound=Union[Enum1, Enum2]) # Case 1... Success
Enums = TypeVar("Enums", Enum1, Enum2) # Case 2... error: Incompatible return value
def _enum_to_num(val: int, cast_enum: EnumMeta) -> Enums:
return cast_enum(val)
def get_some_enum(val: int) -> Enum1:
return _enum_to_num(val, Enum1)
def get_another_enum(val: int) -> Enum2:
return _enum_to_num(val, Enum2) # line 35
mypy==0.770
:
Case 1
:Success: no issues found
Case 2
:35: error: Incompatible return value type (got "Enum1", expected "Enum2")
bound=Union[Enum1, Enum2]
)时,以下是合法的:
Union[Enum1, Enum2]
Enum1
Enum2
A, B
) 时,以下是合法的:
Enum1
Enum2
Union
案件。
最佳答案
我认为发生错误是因为类型检查器没有足够的信息来通过查看输入参数的类型来推断返回类型。虽然处理可能会有所改善。
假设您有一个简单的通用函数:
Enums = TypeVar("Enums", Enum1, Enum2)
def add(x: Enums, y: Enums) -> Enums:
return x
add(Enum2.MEMBER3, Enum2.MEMBER4) # ok, return Enum2
add(Enum1.MEMBER1, Enum1.MEMBER2) # ok, return Enum1
add(Enum2.MEMBER3, Enum1.MEMBER2) # not ok
_enum_to_num
同样,类型检查器无法推断返回类型,它只是不知道将返回什么类型,因为它不知道
cast_enum
将返回什么类型。 :
def _enum_to_num(val: int, cast_enum: EnumMeta) -> Enums:
return cast_enum(val)
cast_enum
的类型,即
EnumMeta
,类型检查器无法判断是否
cast_enum
将返回
Enums
或不。看起来它只是假设它会返回
Enum1
,并导致
_enum_to_num(val, Enum2)
中的错误.
_enum_to_num(val, Enum2)
将返回
Enum2
因为你知道
cast_enum
的值是
Enum2
.该值是类型检查器通常不会触及的东西。可能会混淆,变量
cast_enum
的值是
Enum2
, 而
cast_enum
的类型是
EnumMeta
,虽然
Enum2
是一种类型。
cast_enum
来解决。使用
typing.Type
:
from typing import TypeVar, Union, Type
...
def _enum_to_num(val: int, cast_enum: Type[Enums]) -> Enums:
return cast_enum(val)
关于Python mypy 检查 TypeVar(bound=Union[A, B]) 的返回类型不会出错 vs TypeVar(A, B) 会出错,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61335410/
我正在努力理解以下两个 TypeVar 之间的区别年代: from typing import TypeVar, Union class A: pass class B: pass T = TypeV
我被困在试图理解 TypeVar 的边界上当以两种不同的方式使用它时: Enums = TypeVar("Enums", Enum1, Enum2) Enums = TypeVar("Enums",
我有一个通用类 Graph[Generic[T], object] . 我的问题是,是否有任何函数返回作为泛型传递给类 Graph 的类型? >>> g = Graph[int]() >>> magi
我问自己是否有关于使用 TypeVar 的最佳实践和 overload在 python 中用于返回与输入相同类型的函数。考虑这些例子。 示例 1. 使用 TypeVar : from typing i
我正在使用 mypy和 typing python中的模块。想象一下我有一个泛型类型: ContainerT = TypeVar('ContainerT') class Thingy(Generic[
作为一名 C++ 程序员,以下代码对我来说似乎很自然,但它无法运行: from typing import TypeVar, Generic, List, NewType TPopMember = T
众所周知,在 C# 中,可以指定自定义属性规范的目标,如示例中所示 [method: SomeDecoration] [return: SomeOtherMark] int MyMethod(); “
我正在尝试使用 TypeVar 将 init 参数指示为某种类型。 但我做错了,或者它甚至可能不可能。 from typing import TypeVar T=TypeVar("T") class
假设我有一些通用函数: def foo(*args): for arg in args: print(arg) 如果我想输入提示 *args,根据 PEP我只需要指定类型 1
在Python中Documentation ,我们发现: T = TypeVar('T') # Can be anything S = TypeVar('S', bound=
TypeVar和 NewType似乎相关,但我不确定何时应该使用它们,或者在运行时和静态时有什么区别。 最佳答案 这两个概念的相关性并不比任何其他与类型相关的概念更多。 简而言之,TypeVar 是一
例如,我有一段代码如下: from typing import Type, TypeVar, cast class SuperClass: pass T = TypeVar('T', boun
[ERROR] Failed to execute goal org.apache.maven.plugins:maven-javadoc-plugin:2.10.3:jar (package-jav
我试图理解以下代码段中的类型提示 Getter[T]: 简化示例 T = TypeVar('T') Getter = Callable[[T, str], str] class AbstractCla
我正在使用 pytype (2019.10.17,最新版本到现在)作为我的代码类型检查器开发了一个工具,可以通过索引文件随机读取msgpack文件,索引文件记录了每条消息的位置(msgpack文件中的
出于某种原因,这段代码被认为是一个问题: from typing import * T = TypeVar("T", bound="Foo") S = TypeVar("S") class Foo(G
我在以下代码中遇到了问题,至少根据 mypy 是这样的: from multiprocessing import Pool from typing import Tuple, TypeVar T =
假设我有一个基类 from typing import List, Optional class Node: def __init__(self, name: str) -> None:
我想实现一个通用字典,将文本键映射到 MyConstrainingClass 或继承自 MyConstrainingClass 的类,因此我声明了 TypeVar 和 MyDict 类如下: from
如果我想要一个可以是多种可能类型的类型,Unions 似乎就是我表示的方式: U = Union[int, str] U 可以是 int 或 str。 我注意到,TypeVar允许可选的 var-ar
我是一名优秀的程序员,十分优秀!