命名元组的构造方式
typing.NamedTuple尚无法从类继承。您必须编写自己的元类来扩展
typing.NamedTuplemeta该类,以使子类能够工作,即使如此,by生成的类
collections.namedtuple()也不能构建为extend
相反,您想使用新
dataclasses模块定义类并实现继承:
from dataclasses import dataclass@dataclass(frozen=True)class base: x: int y: int@dataclass(frozen=True)class baseExtended(base): z: str
该模块是Python 3.7中的新增功能,但您可以在Python 3.6上
pip installdataclasses向后移植。
上面定义了两个具有
x和
y属性的不可变类,
baseExtended该类又添加了一个属性。
baseExtended是的完整子类
base,因此出于键入目的,适合该
DoSomething()功能的要求。
这些类不是全名的元组,因为它们没有长度或不支持索引,但是通过创建继承自的基类
collections.abc.Sequence并添加两个方法来按索引访问字段,可以轻松添加这些类。如果添加
order=True到
@dataclass()装饰器中,则您的实例将变得完全可订购,其元组的命名方式如下:
from collections.abc import Sequencefrom dataclasses import dataclass, fieldsclass DataclassSequence(Sequence): # make a dataclass tuple-like by accessing fields by index def __getitem__(self, i): return getattr(self, fields(self)[i].name) def __len__(self): return len(fields(self))@dataclass(frozen=True, order=True)class base(DataclassSequence): x: int y: int
MyPy将很快
dataclasses明确支持;在版本0.600中,您仍然会遇到错误,因为它无法识别
dataclasses模块导入或
__new__生成了方法。
在Python
3.6和更低版本中,您还可以安装
attrs项目以实现相同的效果。上面的序列基类如下所示
attrs:
from collections.abc import Sequenceimport attrclass AttrsSequence(Sequence): # make a dataclass tuple-like by accessing fields by index def __getitem__(self, i): return getattr(self, attr.fields(type(self))[i].name) def __len__(self): return len(attr.fields(type(self)))@attr.s(frozen=True, auto_attribs=True)class base(AttrsSequence): x: int y: int
dataclasses直接基于
attrs,并
attrs提供更多功能;mypy完全支持使用生成的类
attrs。



