- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我试图理解以下代码段中的类型提示 Getter[T]
:
T = TypeVar('T')
Getter = Callable[[T, str], str]
class AbstractClass(abc.ABC):
@abc.abstractmethod
def extract(
self,
get_from_carrier: Getter[T], # <---- See here
...
) -> Context:
帮助非常感谢,因为我一直在为此伤脑筋。
原始源代码来自OpenTelemetry project file "textmap.py" :
import abc
import typing
from opentelemetry.context.context import Context
TextMapPropagatorT = typing.TypeVar("TextMapPropagatorT")
Setter = typing.Callable[[TextMapPropagatorT, str, str], None]
Getter = typing.Callable[[TextMapPropagatorT, str], typing.List[str]]
class TextMapPropagator(abc.ABC):
"""This class provides an interface that enables extracting and injecting
context into headers of HTTP requests.
...
"""
@abc.abstractmethod
def extract(
self,
get_from_carrier: Getter[TextMapPropagatorT],
carrier: TextMapPropagatorT,
context: typing.Optional[Context] = None,
) -> Context:
最佳答案
一个 Callable 后跟一个类型变量意味着这个 callable 是一个泛型函数,它接受一个或多个泛型类型 T
的参数。
类型变量 T
是任何泛型类型的参数。
行:
Getter = Callable[[T, str], str]
将 Getter
定义为可调用函数的类型别名,该函数的参数为泛型 T
和字符串,返回类型为字符串。
因此,行:
get_from_carrier: Getter[T]
定义一个作为通用函数的参数 (get_from_carrier
)。并且泛型函数的第一个参数是泛型类型T
。
通过查看具体示例可以更好地理解这一点。请参阅下面来自 "instrumentation/opentelemetry-instrumentation-asgi/src/opentelemetry/instrumentation/asgi/init.py " 的 propagators.extract
:
在调用 propagators.extract
时,函数 get_header_from_scope
是一个可调用函数,它的第一个参数是 dict
类型,而这个 dict
用作 TextMapPropagatorT
。
def get_header_from_scope(scope: dict, header_name: str) -> typing.List[str]:
"""Retrieve a HTTP header value from the ASGI scope.
Returns:
A list with a single string with the header value if it exists, else an empty list.
"""
headers = scope.get("headers")
return [
value.decode("utf8")
for (key, value) in headers
if key.decode("utf8") == header_name
]
...
class OpenTelemetryMiddleware:
"""The ASGI application middleware.
...
"""
...
async def __call__(self, scope, receive, send):
"""The ASGI application ... """
if scope["type"] not in ("http", "websocket"):
return await self.app(scope, receive, send)
token = context.attach(
propagators.extract(get_header_from_scope, scope)
)
关于Python 类型提示 : What does Callable followed by a TypeVar mean?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/64089275/
我正在努力理解以下两个 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
我是一名优秀的程序员,十分优秀!