Ты ищешь Optional
.
Поскольку ваш тип возврата может быть datetime
(как возвращено из datetime.utcnow()
) или None
вы должны использовать Optional[datetime]
:
from typing import Optional
def get_some_date(some_argument: int=None) -> Optional[datetime]:
# as defined
Из документации о наборе текста Optional
есть сокращение для:
Optional[X]
эквивалентно Union[X, None]
.
где Union[X, Y]
означает значение типа X
или Y
.
Если вы хотите быть откровенным из-за опасений, на которые могут наткнуться другие Optional
и не осознающих его смысла, вы всегда можете использовать Union
:
from typing import Union
def get_some_date(some_argument: int=None) -> Union[datetime, None]:
Но я сомневаюсь, что это хорошая идея, Optional
это ориентировочное имя, и оно спасает пару нажатий клавиш.
Как указано в комментариях @ Michael0x2a преобразуется Union[T, None]
в Union[T, type(None)]
так что нет необходимости использовать type
здесь.
Визуально они могут отличаться, но программно, в обоих случаях результат абсолютно одинаков ; Union[datetime.datetime, NoneType]
будет тип хранится в get_some_date.__annotations__
* :
>>> from typing import get_type_hints
>>> print(get_type_hints(get_some_date))
{'return': typing.Union[datetime.datetime, NoneType],
'some_argument': typing.Union[int, NoneType]}
* Используйте, typing.get_type_hints
чтобы захватить __annotations__
атрибут объекта вместо прямого доступа к нему.
Union[datetime, type(None)]
доUnion[datetime, None]
- согласно PEP 484 , использованиеNone
внутри аннотации типа всегда рассматривается как эквивалентноеtype(None)
. (typing
Документация фактически используетNone
в большинстве случаев, но не здесь, что является недосмотром).Optional[T]
Типа хорошо известен в сообществе функционального программирования. Читатель не только узнает, что это означаетUnion[T, None]
, но также распознает шаблон использования, который функция должна возвращать None, если нет значимого ответа, есть ошибка или результат не найден.