phi*_*x2e 2 python python-3.x mypy python-typing
我遇到了以下代码的问题,至少根据 mypy 是这样的:
from multiprocessing import Pool
from typing import Tuple, TypeVar
T = TypeVar("T", int, str)
def do_something(a: T) -> Tuple[T, bool]:
# Something happening here...
return a, False
if __name__ == "__main__":
pool = Pool(processes=10)
nums = list(range(100000, 1000000))
for r in pool.imap_unordered(do_something, nums):
if r[1]:
print(f"Got {r[0]}")
Run Code Online (Sandbox Code Playgroud)
当我使用 mypy 检查它时,出现以下错误:
error: Argument 1 to "imap_unordered" of "Pool" has incompatible type "Callable[[T], Tuple[T, bool]]"; expected "Callable[[int], Tuple[T, bool]]"
Run Code Online (Sandbox Code Playgroud)
实际类型显然应该满足预期类型。我做错了什么还是 mypy 或 multiprocessing.Pool 中的错误?
预先感谢您的任何评论。
正如 Jasmijn 的评论所示,这是一个最小的示例:
from typing import TypeVar
T = TypeVar("T")
def do_something(a: T) -> T:
return a
map(do_something, [1])
Run Code Online (Sandbox Code Playgroud)
此操作失败并出现相同的错误。我认为这是 的限制mypy,但我们可以通过引入一个额外的辅助函数来修复它,通过该函数我们显式提供类型而不是mypy必须推断它。
def new_do_something(t: Type[T]) -> Callable[[T], T]:
return do_something
Run Code Online (Sandbox Code Playgroud)
使用上面的内容,这不再导致任何错误,同时仍然允许do_something通用:
map(new_do_something(int), [1])
Run Code Online (Sandbox Code Playgroud)
对于您的原始示例,修改后的版本将如下所示:
from multiprocessing import Pool
from typing import Tuple, TypeVar, Type, Callable
T = TypeVar("T", int, str)
def do_something(a: T) -> Tuple[T, bool]:
# Something happening here...
return a, False
def new_do_something(t: Type[T]) -> Callable[[T], Tuple[T, bool]]:
return do_something
if __name__ == "__main__":
pool = Pool(processes=10)
nums = list(range(100000, 1000000))
for r in pool.imap_unordered(new_do_something(int), nums):
if r[1]:
print(f"Got {r[0]}")
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
1136 次 |
| 最近记录: |