- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
有一个函数 ( f ) 使用函数签名 ( g ),它采用已知的第一组参数和任意数量的关键字参数 **kwargs
.有没有办法包含 **kwargs
在 ( f ) 中描述的 ( g ) 的类型签名中?
例如:
from typing import Callable, Any
from functools import wraps
import math
def comparator(f: Callable[[Any, Any], bool]) -> Callable[[str], bool]:
@wraps(f)
def wrapper(input_string: str, **kwargs) -> bool:
a, b, *_ = input_string.split(" ")
return f(eval(a), eval(b), **kwargs)
return wrapper
@comparator
def equal(a, b):
return a == b
@comparator
def equal_within(a, b, rel_tol=1e-09, abs_tol=0.0):
return math.isclose(a, b, rel_tol=rel_tol, abs_tol=abs_tol)
# All following statements should print `True`
print(equal("1 1") == True)
print(equal("1 2") == False)
print(equal_within("5.0 4.99998", rel_tol=1e-5) == True)
print(equal_within("5.0 4.99998") == False)
comparator
包装它的论点
f
与
wrapper
,它使用
f
的输入作为字符串,解析它并使用
f
评估它.在这种情况下,Pycharm 会给出警告
return f(eval(a), eval(b), **kwargs)
来电
f
带有意外的参数
**kwargs
,与预期的签名不匹配。
Any
或
...
到
f
的类型签名像
f: Callable[[Any, Any, ...], bool]
f: Callable[[Any, Any, Any], bool]
f
至少接受 2 个参数,而不是正好 3 个。
Callable
args 定义以
...
打开喜欢
f: Callable[..., bool]
,但我想知道是否有更合适的解决方案。
TypeError: Callable[[arg, ...], result]: each arg must be a type. Got Ellipsis.
最佳答案
tl;博士: Protocol
可能是已实现的最接近的功能,但仍不足以满足您的需求。见 this issue详情。
完整答案:
我认为最接近您要求的功能是 Protocol
,它是在 Python 3.8 中引入的(并通过 typing_extensions
向后移植到旧版 Python)。它允许您定义 Protocol
描述类型行为的子类,很像其他语言中的“接口(interface)”或“特征”。对于函数,支持类似的语法:
from typing import Protocol
# from typing_extensions import Protocol # if you're using Python 3.6
class MyFunction(Protocol):
def __call__(self, a: Any, b: Any, **kwargs) -> bool: ...
def decorator(func: MyFunction):
...
@decorator # this type-checks
def my_function(a, b, **kwargs) -> bool:
return a == b
在这种情况下,任何具有匹配签名的函数都可以匹配
MyFunction
类型。
**kwargs
参数)。到目前为止,仍然无法指定该函数可以(可选地)采用任何关键字参数。
This GitHub issue讨论了当前限制下的一些可能(尽管冗长或复杂)的解决方案。
Callable[..., bool]
作为
f
的类型注释.但是,可以使用
Protocol
细化包装器的返回类型:
class ReturnFunc(Protocol):
def __call__(self, s: str, **kwargs) -> bool: ...
def comparator(f: Callable[..., bool]) -> ReturnFunc:
....
这消除了
equal_within("5.0 4.99998", rel_tol=1e-5)
处的“意外关键字参数”错误。 .
关于python - 需要 **kwargs 的 Callable 的类型注释,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61569324/
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 8 年前。 Improve th
我想知道如果我们有一个引用 const 的函数参数会发生什么功能如下图。 版本 1 int anotherFunc() { std::cout<<"inside anotherFunc"<
我正在尝试运行YOLOv8重新训练的对象检测测试,但我一直收到此错误。。我已经试过安装gnu-cobol和更新西芹了,还有其他想法吗?谢谢
我做了一个静态类方法(这里称为“函数”)f需要一个列表 Callable小号: import java.util.concurrent.*; import java.util.*; class A {
以下是我的类定义: class logline: def __init__(self,t,cmp,msg): self.t = t self.cmp = cmp
我正在用 dart 做一个小实验,我找不到一种方法来确定一个变量是否是“可调用的”,而无需显式检查每种类型(字符串、整数、 bool 等),并猜测它是否是可调用的,如果没有的话那些。我还尝试了一个 t
我大量使用来自 python 3 的 python 类型支持。 最近我试图将一个函数作为参数传递,但我没有找到使用 kwargs 的任何帮助。在 typing.Callable签名。 请检查下面的代码
每当我运行实现可调用的程序时,我都会以顺序形式获得输出。 就像,这是我的程序: package com.handson; import java.util.concurrent.ArrayBlocki
我编写了一个注释(在Spring Boot应用程序中)并尝试将其应用到Callable的call()方法上,但它不起作用,但另一方面,当应用于普通方法时(请参阅下面的代码),它有效,这一直困扰着我,你
我试图将对象列表拆分为较小的子列表,并在不同的线程上单独处理它们。所以我有以下代码: List instances = xmlInstance.readInstancesFromXml
我想我可以用 std.traits.functionAttributes 来做到这一点,但它不支持 static。对于任何类型的可调用对象(包含 opCall 的结构),我如何判断该可调用对象是否使用
我是新来的,如果我把这个放到错误的主题中,很抱歉? 我的问题: class TaskEol implements Callable> { ArrayList coordinates =
我有一些代码可以从目录中的多个 JAR 动态加载类。因为 JAR 中的代码是不受信任的,所以我希望通过对它们进行“沙盒处理”来保护主应用程序免受编码不良或恶意动态类的影响。我想做的一件事是“时间盒”不
这个问题在这里已经有了答案: Overriding special methods on an instance (5 个答案) 关闭 9 年前。 我有以下代码 import numpy as np
我正在尝试制作一个类似于 https://github.com/ElgarL/TownyChat/blob/master/src/com/palmergames/bukkit/TownyChat/To
有人可以解释为什么要继承未参数化和参数化的Callable: from typing import Callable from typing import NoReturn from typing i
我有一个任务要以固定速率运行。但是,我还需要每次执行后的任务结果。这是我尝试过的: 任务 class ScheduledWork implements Callable { public St
给定一个实例 x的 Callable , 我怎样才能运行 x在一个单独的进程中,以便我可以重定向进程的标准输入和输出?例如,有没有办法构建一个 Process来自Callable ?有没有标准Exec
我有以下可调用对象: public class Worker implements Callable{ @Override public Boolean call(){ boo
现在很清楚了what a metaclass is ,有一个相关的概念,我一直在使用,但不知道它的真正含义。 我想每个人都犯了一次括号错误,导致“对象不可调用”异常。更何况,使用 __init__ 和
我是一名优秀的程序员,十分优秀!