如果我有一个简单dataclass
的可变默认值,据我所知,我需要使用default_factory
.
但是,由于 lambda,这使得该类不可腌制:
@dataclass
class ExperimentConfig:
features: List[str] = field(
default_factory=lambda: ["value1", "value2"])
所以如果我们腌制它:
import cloudpickle
c = ExperimentConfig()
cloudpickle.dumps(c)
酸洗会返回:
TypeError: can't pickle mappingproxy objects
这是由于在 中mappingproxy
可见的对象c.__dataclass_fields__
:
{'features':
Field(name='features',
type=typing.List[str],
default=<dataclasses._MISSING_TYPE object at 0x7f6ca8434588>,
default_factory=<function ExperimentConfig.<lambda> at 0x7f6c9951b268>,
init=True,
repr=True,
hash=None,
compare=True,
metadata=mappingproxy({}),
_field_type=_FIELD
)
}
如何使课程可腌制?我需要这样做才能将其发送Parallel
到joblib
.