10

我想问的示例代码如下。
互联网上的示例都没有尝试像这样重载参数值。
其中一个参数是 bool 值,我想重载一个基于 bool 值而不是通常的参数类型的方法。

from typing import overload, Union

@overload
def myfunc(arg:bool=True)-> str: ...

@overload
def myfunc(arg:bool=False)-> int: ...

def myfunc(arg:bool)->Union[int, str]:
    if arg: return "something"
    else: return 0

上述示例代码中的重载代码是否正确?你能给出一个提到这种重载的例子/博客/来源吗,因为我在 Python 文档和pep-484
中找不到任何东西

我发现一种可能的方法是typing.Literal使用最新的 python 文档(因为 python v3.8)

from typing import overload, Union, Literal

@overload
def myfunc(arg:Literal[True])-> str: ...

@overload
def myfunc(arg:Literal[False])-> int: ...

def myfunc(arg:bool)->Union[int, str]:
    if arg: return "something"
    else: return 0

但是我还不能迁移到 python 3.8,因为我正在处理仍然在 python 3.6 上的生产代码,很快就会升级到 3.7。
因此,我仍在寻找有关如何在 python 3.6 中实现这一点的答案

4

2 回答 2

13

安装类型扩展模块,其中包含各种类型结构的官方反向移植。然后做:

from typing import overload, Union

# typing_extensions defines Literal for Python 3.7 and earlier, but
# re-exports it from 'typing' for later versions of Python.
from typing_extensions import Literal

@overload
def myfunc(arg: Literal[True]) -> str: ...

@overload
def myfunc(arg: Literal[False]) -> int: ...

@overload
def myfunc(arg: bool) -> Union[str, int]: ...

def myfunc(arg: bool) -> Union[int, str]:
    if arg: return "something"
    else: return 0

请参阅mypy 文档中关于文字类型的第一个示例,了解为什么我在 bool 中包含第三个重载。

于 2019-12-16T17:37:49.193 回答
8

在正确接受的答案的基础上,@overloading默认(关键字)参数可以实现如下:

from typing import overload, Union, Literal

@overload
def myfunc(arg: Literal[True] = True) -> str: ...

@overload
def myfunc(arg: Literal[False]) -> int: ...

def myfunc(arg: bool =  True) -> Union[int, str]:
    if arg: return "something"
    else: return 0

第一个重载(with Literal[True])用于对函数调用进行类型检查myfunc(True)myfunc()而第二个重载(with Literal[False])用于对函数调用进行类型检查myfunc(False)

于 2021-01-04T01:03:43.227 回答