Я пытаюсь аннотации типов Python с абстрактными базовыми классами писать некоторые интерфейсы. Есть ли способ аннотировать возможные типы *args
и **kwargs
?Аннотации типов для * args и ** kwargs
Например, как можно выразить, что разумные аргументы функции являются либо int
, либо двумя int
s? type(args)
дает Tuple
, поэтому я предполагал, что аннотировать этот тип как Union[Tuple[int, int], Tuple[int]]
, но это не сработает.
from typing import Union, Tuple
def foo(*args: Union[Tuple[int, int], Tuple[int]]):
try:
i, j = args
return i + j
except ValueError:
assert len(args) == 1
i = args[0]
return i
# ok
print(foo((1,)))
print(foo((1, 2)))
# mypy does not like this
print(foo(1))
print(foo(1, 2))
Сообщения об ошибках mypy:
t.py: note: In function "foo":
t.py:6: error: Unsupported operand types for + ("tuple" and "Union[Tuple[int, int], Tuple[int]]")
t.py: note: At top level:
t.py:12: error: Argument 1 to "foo" has incompatible type "int"; expected "Union[Tuple[int, int], Tuple[int]]"
t.py:14: error: Argument 1 to "foo" has incompatible type "int"; expected "Union[Tuple[int, int], Tuple[int]]"
t.py:15: error: Argument 1 to "foo" has incompatible type "int"; expected "Union[Tuple[int, int], Tuple[int]]"
t.py:15: error: Argument 2 to "foo" has incompatible type "int"; expected "Union[Tuple[int, int], Tuple[int]]"
Это имеет смысл, что mypy не нравится это для вызова функции, потому что он ожидает, что там будет в самом вызову tuple
. Добавление после распаковки также дает ошибку ввода, которую я не понимаю.
Как аннотировать чувствительные типы для *args
и **kwargs
?
Любопытно, зачем добавлять 'Факультативный'? Что-то изменилось в Python или вы передумали? Это по-прежнему не является строго необходимым из-за «Нет» по умолчанию? – Praxeolitic
@Praxeolitic да, на практике автоматическая подразумеваемая аннотация «Необязательный», когда вы используете значение «Нет» в качестве значения по умолчанию, усложняло некоторые неудобства и теперь удаляется из PEP. –
[Вот ссылка, обсуждающая это] (https://github.com/python/typing/issues/275) для заинтересованных. В будущем это, безусловно, звучит как явный «Факультативный». –