引号中的mypy显式类型提示仍然未给出定义的错误

时间:2016-06-09 19:03:24

标签: python typing mypy

我正在尝试做以下事情:

self.sender = None # type: 'Node'

我无法导入Node,因为我会得到一个循环。所以我用这里提到的引号写它 http://mypy.readthedocs.io/en/latest/common_issues.html#import-cycles 但我仍然收到以下错误

error: Name 'Node' is not defined

有没有解决方案?

谢谢!

1 个答案:

答案 0 :(得分:2)

简短回答,您需要包含该类的模块名称,并且需要在一些无法访问的代码中导入该模块,如下所示:

if False:
    # for forward-reference type-checking:
    import mymodule

class MyClass(object):
    def __init__(self):
        self.sender = None  # type: mymodule.Node

为了理解为什么需要它(及其工作原理),您必须首先意识到mypy正在进行静态代码分析。这意味着它不会导入您的模块,它会解析和分析从模块文件中读取的文本。

导入上面的模块时,import mymodule行将永远不会运行,因此会避免您的循环导入,但mypy仍然可以解析。这就是mypy在分析过程中如何解析对mymodule.Node的引用。

为了完整起见,我应该提到您不需要使用模块名称,您可以使用在解析过程中不会引起冲突的任何名称:

if False:
    from mymodule import Node

class MyClass(object):
    def __init__(self):
        self.sender = None  # type: Node

另请注意,您不需要在注释中显示的类型名称周围使用引号。只有当类型注释直接出现在python对象中时,才需要这样做。以下是可能发生这种情况的一些情况:

from typing import Optional, NamedTuple
if False:
    from mymodule import Node

NodeInfo = NamedTuple('NodeInfo', [('node', 'Node'), ('info', dict)])

class MyClass(object):
    def __init__(self, sender: Optional['Node'] = None):
        self.sender = sender