【发布时间】:2015-12-16 18:51:00
【问题描述】:
我正在开发一个使用 Pickle 来实现存档游戏的游戏项目(我知道这样做的缺点 - 我们不在这里讨论)。这非常有效:不幸的是,标准 Pickle 无法处理我希望在未来版本中做的一些事情,所以我改用 Dill。不幸的是,它不起作用:它会在加载保存时提供_pickle.UnpicklingError: pickle exhausted before end of frame。
重申:这段代码和我正在使用的测试用例与 Pickle 完美配合。只有 Dill 有问题。
我正在像这样导入 Dill:
try:
import dill as pickle
except ImportError:
print("Failed to load Dill serialization library: some features may not work correctly.")
import pickle
完整的回溯是这样的:
Traceback (most recent call last):
File "C:/Users/Schilcote/workspace/pyweek19/main.py", line 605, in game_init
gamestate=pickle.load(open(os.path.join(_savedir,"save.sav"),"rb"))
File "C:\Python34\lib\site-packages\dill\dill.py", line 199, in load
obj = pik.load()
File "C:\Python34\Lib\pickle.py", line 1036, in load
dispatch[key[0]](self)
File "C:\Python34\Lib\pickle.py", line 1321, in load_global
module = self.readline()[:-1].decode("utf-8")
File "C:\Python34\Lib\pickle.py", line 247, in readline
"pickle exhausted before end of frame")
_pickle.UnpicklingError: pickle exhausted before end of frame
我什至不知道如何开始诊断。怎么回事?
编辑:
为了澄清,错误出现在de序列化。
【问题讨论】:
-
您在测试中使用的
save.sav文件是如何生成的?即它是使用pickle或dill生成的吗? -
@Sebastian With
dill. -
@Sebastian 澄清一下,我总是针对
pickle生成的文件测试pickle,并针对dill生成的文件测试dill。我没有尝试将两者混合,但我怀疑会发生什么好事。 -
^1 因为那个标题
-
我很确定这是 Dill 中的一个直接错误。 @Mike McKerns?
标签: python python-3.x serialization pickle dill