假设我有一个函数:
def get_some_date(some_argument: int=None) -> %datetime_or_None%: if some_argument is not None and some_argument == 1: return datetime.utcnow() else: return None
如何为可以指定的东西指定返回类型None?
None
您正在寻找Optional。
Optional
由于您的返回类型可以是datetime(从返回datetime.utcnow()),None也应该使用Optional[datetime]:
datetime
datetime.utcnow()
Optional[datetime]
from typing import Optional def get_some_date(some_argument: int=None) -> Optional[datetime]: # as defined
在有关打字的文档中,Optional是以下内容的简写:
Optional[X]等价于Union[X, None]。
Optional[X]
Union[X, None]
其中Union[X, Y]表示类型X或的值Y。
Union[X, Y]
X
Y
如果由于担心别人可能偶然发现Optional而没有意识到它的含义而希望变得露骨,则可以始终使用Union:
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[T, None]
Union[T, type(None)]
type
在视觉上,这两种方法可能有所不同,但在编程上,结果是 完全相同的 ;Union[datetime.datetime, NoneType]将是存储在get_some_date.__annotations__*中的类型:
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__直接访问它的属性来代替。
typing.get_type_hints
__annotations__