不能。kw_only=True 时所有字段均强制关键字传参,无字段级豁免;其为类级编译期约束,统一重写__init__签名为keyword-only形式;Python 3.10+字段级kw_only在此场景下被忽略。
不能。一旦设置了 kw_only=True,所有字段(包括显式声明的)都强制要求关键字传参——这是 dataclass 的硬性语义,没有例外机制或字段级覆盖开关。
因为 kw_only 是作用于整个类的编译期约束,它会统一重写 __init__ 的签名,把所有字段挪到 *args 之后、**kwargs 之前,并标记为 keyword-only

def __init__(self, a, b, *, c, d): 形式)。字段定义里加 default 或 field(default=...) 不会影响这个行为,只影响是否必须传值。
有三个可行路径,按推荐度排序:
kw_only=True,改用 __post_init__ 手动校验关键字段是否被传入(适合逻辑校验强于语法强制的场景)__init__),子类用 kw_only=True 补充其余字段@dataclass,手写 __init__ —— 虽失去自动生成方法(如 __repr__),但完全可控;可配合 dataclasses.fields() 复用字段元数据例如拆分子类方式:
@dataclass
class Base:
x: int
y: str
@dataclass(kw_only=True)
class Derived(Base):
z: float
w: bool = False
此时 Derived(1, "a", z=2.0) 合法,x 和 y 来自父类位置参数,z 和 w 强制关键字。
Python 3.10+ 支持字段级 kw_only(通过 field(kw_only=True)),但它只在 kw_only=False 的 dataclass 中生效;一旦类级设了 kw_only=True,字段级设置会被忽略——文档明确写了 “This is ignored if the class is defined with kw_only=True”。别被 IDE 提示或旧版博客误导。