9

我有以下课程:

class WordItem:
    def __init__(self, phrase: str, word_type: WORD_TYPE):
        self.id = f'{phrase}_{word_type.name.lower()}'
        self.phrase = phrase
        self.word_type = word_type
        @classmethod

    def from_payload(cls, payload: Dict[str, Any]) -> 'WordItem':
        return cls(**payload)

如何将此类重写为数据类

具体来说,该id字段应该如何声明?它有一个生成的值,而不是创建实例的代码将提供的字段。

4

1 回答 1

25

只需将您的每个属性移动到类上的类型注释声明中,该类已用@dataclasses.dataclassdecorator进行了装饰。

id您可以在__post_init__方法中生成值;确保将其标记为对__init__带有dataclass.field()对象的参数的豁免:

from dataclasses import dataclass, field    

@dataclass
class WordItem:
    id: str = field(init=False)
    phrase: str
    word_type: WORD_TYPE

    def __post_init__(self):
        self.id = f'{self.phrase}_{self.word_type.name.lower()}'

演示:

>>> from types import SimpleNamespace
>>> wt = SimpleNamespace(name='Python')
>>> WordItem('await', wt)
WordItem(id='await_python', phrase='await', word_type=namespace(name='Python'))
于 2018-10-03T13:26:28.177 回答