以下代码无法按预期工作。显然,我不能在类定义中使用类自己的类型:
class Foo:
def __init__(self, key :str) -> None:
self.key = key
def __eq__(self, other :Foo) -> bool:
return self.key == other.key
print('should be true: ', Foo('abc') == Foo('abc'))
print('should be false: ', Foo('abc') == Foo('def'))
运行的结果是:
Traceback (most recent call last):
File "class_own_type.py", line 1, in <module>
class Foo:
File "class_own_type.py", line 5, in Foo
def __eq__(self, other :Foo) -> bool:
NameError: name 'Foo' is not defined
另外,检查代码mypy
返回:
class_own_type.py:5: error: Argument 1 of "__eq__" incompatible with supertype "object"
如何更正此代码以使其对 Python 和 mypy 都有效?
When Foo.__eq__
正在定义名称Foo
仍未绑定,因为类本身尚未创建。请记住:函数参数在函数定义时计算,而不是在函数调用时计算。
从 Python 3.7+ 开始,您可以推迟对注释的评估 https://www.python.org/dev/peps/pep-0563/通过在模块顶部添加此导入:
from __future__ import annotations
对于 Python
class Foo:
def __init__(self, key: str) -> None:
self.key = key
def __eq__(self, other: 'Foo') -> bool:
return self.key == other.key
print('should be true: ', Foo('abc') == Foo('abc'))
print('should be false: ', Foo('abc') == Foo('def'))
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)