繁体   English   中英

如何打开 .pkl 文件

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM