微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

使用pickle检索保存的对象时出错

如何解决使用pickle检索保存的对象时出错

使用基于 MESA 代理的建模包。使用 pickle 来保存我的中间模型的状态。但是当检索保存的模型时,执行最终会出错:

  File "/home/demonwolf/PycharmProjects/pythonProject1/main.py",line 281,in <module>
    empty_model = pickle.load(f)
  File "/home/demonwolf/anaconda3/envs/ABM/lib/python3.7/codecs.py",line 322,in decode
    (result,consumed) = self._buffer_decode(data,self.errors,final)
UnicodeDecodeError: 'utf-8' codec can't decode byte 0x80 in position 0: invalid start byte```



Any help would be appreciated.
Thanks in advance.

解决方法

文件(f 中的 pickle.load(f) 参数)应该以二进制读取 (rb) 模式打开,而不是默认文本 (r) 模式。>

with open("path/to/your/pickle.bin","rb") as f:
    empty_model = pickle.load(f)

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。