是否有可能在Python attr中自引用类型

问题描述 投票:0回答:3

我希望做这样的事情:

@attr.s
class A(object):
    a_dict = attr.ib(factory=Dict, type=Dict[str, A], validator=optional(instance_of(Dict)))

可以像type=Dict一样输入它,但我想知道你是否可以像type=Dict[str, cls]那样进行自我引用,但它可能受到Python可能性的限制。

谢谢。

python python-2.7 python-attrs
3个回答
1
投票

如果我解释正确,你想要的是这个:

from typing import Dict, Optional

import attr

from attr.validators import optional, instance_of


@attr.s
class A(object):
    a_dict = attr.ib(
        factory=dict,
        type=Optional[Dict[str, "A"]],
        validator=optional(instance_of(dict))
    )


A({"key": A(None)})

它通过了mypy。

请注意:

  • 您不能将typing.Dict用于factory,因为它实际上仅用于类型提示,如果您尝试实例化它则会失败。
  • instance_of在内部使用isinstance(),而isinstance({}, Dict)是True,我认为不打算像那样使用它。
  • 如果a_dict是验证器可选的,你还需要通过将它包装在Optional[]中来使用类型注释声明它是可选的。

1
投票

问题是class A(object): A导致NameError: name 'A' is not defined。这意味着在创建定义块时,不能通过名称引用类。

我认为要在键入时解决这个问题,可以使用字符串代替:type=Dict[str, 'A']。我记得看到这是如何制作前向引用,但这可能不对。


1
投票

clsself是按类型赋予类及其实例的名称,它们分别作为参数传递给类方法和实例方法。也不会定义您尝试使用它们的位置。

你可以做的是强制将类型强制为A的非对象超类,如果有的话。

© www.soinside.com 2019 - 2024. All rights reserved.