pickle and cPickle
pickle和cPickle是python对象的转储文件,保存的是python对象
他们分别是python2和python3的对应部分,建议引入的时候采用以下方法:
import cPickle as pickle
except:
import pickle
他们分别遵从不同的协议:
Pickle使用不同的
protocols
方法将您的数据转换为二进制流。
在Python 2有
3个不同的协议
(
0
,
1
,
2
),默认是
0
。
在Python 3有
5层不同的协议
(
0
,
1
,
2
,
3
,
4
),默认是
3
。
您必须在python 3中指定一个低于
3
能够在python 2中加载数据的协议。您可以
protocol
在调用时指定参数
pickle.dump
。
File "/home/dongpeijie/darknet/yolo-compute-map-master/voc_eval.py", line 130, in voc_eval
recs = cPickle.load(f)
ValueError: unsupported pickle protocol: 3
解决方法
:
try passing
protocol=2
to
pkl.dump(worddict, f, protocol=2)
可以直接使用python3 ****.py
如果本地用的是python2.7,那么用Miniconda建立一个3.6的python环境