这个模块提供了一个装饰器和一些函数,用于自动添加生成的 special method,例如 init() 和 repr() 到用户定义的类。 它最初描述于 PEP 557 。
在这些生成的方法中使用的成员变量是使用 PEP 526 类型标注来定义的。 例如以下代码:
from dataclasses import dataclass
@dataclass
class InventoryItem:
"""Class for keeping track of an item in inventory."""
name: str
unit_price: float
quantity_on_hand: int = 0
def total_cost(self) -> float:
return self.unit_price * self.quantity_on_hand
将在添加的内容中包括如下所示的 init():
def __init__(self, name: str, unit_price: float, quantity_on_hand: int = 0):
self.name = name
self.unit_price = unit_price
self.quantity_on_hand = quantity_on_hand
请注意,此方法会自动添加到类中:它不会在上面显示的 InventoryItem 定义中直接指定。
3.7 新版功能.
模块内容
@dataclasses.dataclass(*, init=True, repr=True, eq=True, order=False, unsafe_hash=False, frozen=False, match_args=True, kw_only=False, slots=False, weakref_slot=False)
这个函数是 decorator ,用于将生成的 special method 添加到类中,如下所述。
dataclass() 装饰器会检查类以查找 field。 field 被定义为具有 类型标注 的类变量。 除了下面描述的两个例外,在 dataclass() 中没有什么东西会去检查在变量标注中所指定的类型。
所有生成的方法中的字段顺序是它们在类定义中出现的顺序。
dataclass() 装饰器将向类中添加各种“dunder”方法,如下所述。 如果所添加的方法已存在于类中,则行为将取决于下面所列出的参数。 装饰器会返回调用它的类本身;不会创建新的类。
如果 dataclass() 仅用作没有参数的简单装饰器,它就像它具有此签名中记录的默认值一样。也就是说,这三种 dataclass() 用法是等价的:
@dataclass
class C:
...
@dataclass()
class C:
...
@dataclass(init=True, repr=True, eq=True, order=False, unsafe_hash=False, frozen=False,
match_args=True, kw_only=False, slots=False, weakref_slot=False)
class C:
...
dataclass() 的参数有:
init: 如果为真值(默认),将生成一个 init() 方法。
如果类已定义 init() ,则忽略此参数。
repr :如果为真值(默认),将生成一个 repr() 方法。 生成的 repr 字符串将具有类名以及每个字段的名称和 repr ,按照它们在类中定义的顺序。不包括标记为从 repr 中排除的字段。 例如:InventoryItem(name=‘widget’, unit_price=3.0, quantity_on_hand=10)。
如果类已定义 repr() ,则忽略此参数。
eq :如果为true(默认值),将生成 eq() 方法。此方法将类作为其字段的元组按顺序比较。比较中的两个实例必须是相同的类型。
如果类已定义 eq() ,则忽略此参数。
order :如果为真值(默认为 False ),则 lt() 、 le() 、 gt() 和 ge() 方法将生成。 这将类作为其字段的元组按顺序比较。比较中的两个实例必须是相同的类型。如果 order 为真值并且 eq 为假值 ,则引发 ValueError 。
如果类已经定义了 lt() 、 le() 、 gt() 或者 ge() 中的任意一个,将引发 TypeError 。
unsafe_hash :如果为 False (默认值),则根据 eq 和 frozen 的设置方式生成 hash() 方法。
hash() 由内置的 hash() 使用,当对象被添加到散列集合(如字典和集合)时。有一个 hash() 意味着类的实例是不可变的。可变性是一个复杂的属性,取决于程序员的意图, eq() 的存在性和行为,以及 dataclass() 装饰器中 eq 和 frozen 标志的值。
默认情况下, dataclass() 不会隐式添加 hash() 方法,除非这样做是安全的。 它也不会添加或更改现有的明确定义的 hash<