如何序列化pyspark管道对象?

2024-10-05 17:59:19 发布

您现在位置:Python中文网/ 问答频道 /正文

我正在尝试序列化PySparkPipeline对象,以便以后可以保存和检索它。尝试使用Python pickle库和PySpark的PickleSerializerdumps()调用本身失败。在

在使用本机pickle库时提供代码段。在

pipeline = Pipeline(stages=[tokenizer, hashingTF, lr])
with open ('myfile', 'wb') as f:
   pickle.dump(pipeline,f,2)
with open ('myfile', 'rb') as f:
   pipeline1 = pickle.load(f)

运行时出现以下错误:

^{pr2}$

是否可以序列化PySparkPipeline对象?在


Tags: 对象序列化pipelineas代码段withopenmyfile
1条回答
网友
1楼 · 发布于 2024-10-05 17:59:19

从技术上讲,您可以轻松地pickle Pipeline对象:

from pyspark.ml.pipeline import Pipeline
import pickle

pickle.dumps(Pipeline(stages=[]))
## b'\x80\x03cpyspark.ml.pipeline\nPipeline\nq ...

不能pickle的是SparkTransformers和{},它们只是JVM对象的一个很薄的包装器。如果确实需要,可以将其包装在函数中,例如:

^{pr2}$

但由于它只是一段代码,不存储任何持久性数据,所以看起来并不是特别有用。在

相关问题 更多 >