最近,博主将公司项目从Python2
升级到Python3
,后发现pickle
在Python2
与Python3
中序列化与反序列化不兼容的问题,问题如下:
Python2
中反序列化Python3
中序列化后的数据,将会引发如下错误:ValueError: unsupported pickle protocol: 3
折磨了博主好一阵子,后查阅资料,翻遍书籍,终于找到了兼容的办法,特写此博文记录分享一下:
其实,我们只需要修改Python3
中的序列化与反序列化操作即可:
import pickle
info = pickle.dumps(data, protocol=2)
import pickle
data = pickle.loads(info, encoding="utf-8")
如此,就能达到Python2
与Python3
互相序列化与反序列化的效果啦!!!有遇到相应问题的小伙伴,赶快试试吧!!!