[英]How to open a .pkl file
尽管已经有很多与我的问题相关的主题,但答案对我来说通常是无法理解的,因为我只是“在 Python 中编写脚本”领域的初学者。
这是我的情况:
有一个机器学习软件在其学习阶段结束时以.pkl
格式编写模型。 我想让那些model.pkl
文件可由操作员打开,以检查 model 内部的内容。 因此,我开始编写一个脚本,该脚本将使用pickle.load
方法并将我的model.pkl
中包含的数据写入一个.txt
文件。 这是我开始写的内容:
import pickle
import os
model_path=input("Model Path = ")
with open(model_path, "rb") as model :
load = pickle.load(model, encoding='utf-8')
new_model_path = model_path.split('.pkl')[0] +'.txt'
print("creating new file at : ", new_model_path)
model_readable = open(new_model_path, 'rt')
model_readable.write(load)
print("writing model as readable : ", load)
model_readable.close()
model.close()
如果我尝试运行它,这里是 output:
python3.7 unpickler.py
Model Path = /home/ouriacc/Desktop/workspace/SESAM/Base_de_tests/Anomalie_1/Models/OCSVM/EyeSat/CI_HEATER_CAMERA_VOLTAGE.pkl
Traceback (most recent call last):
File "unpickler.py", line 7, in <module>
load = pickle.load(model, encoding='utf-8')
_pickle.UnpicklingError: invalid load key, '_'.
我找不到有关此错误的任何解释,这并不意味着下载不完整或损坏,这不是我的情况,因为 model.pkl 文件一旦由 AI 软件创建就不会被修改。
有人可以帮我解决错误,甚至可以告诉我实现目标的其他方法吗? 我只需要一个脚本,让用户可以访问 .pkl 文件包含的内容。
非常感谢 !
所以我明白了为什么@wundermahn 会询问scikit-learn
。 看来我的model.pkl
文件是由joblib
生成的,而不是pickle
库。 这就是为什么它显然不起作用的原因。 它通过用pickle.load()
joblid.load()
更改我的代码,并且效果更好!
谢谢 !
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.