pickle and cPickle
pickle和cPickle是python对象的转储文件,保存的是python对象
他们分别是python2和python3的对应部分,建议引入的时候采用以下方法:
try:
import cPickle as pickle
except:
import pickle
他们分别遵从不同的协议:
Pickle使用不同的
protocols
方法将您的数据转换为二进制流。
- 在Python 2有3个不同的协议( ,
1
),默认是 。2
- 在Python 3有5层不同的协议(
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
toprotocol=2
pkl.dump(worddict, f, protocol=2)
- 可以直接使用python3 ****.py
- 如果本地用的是python2.7,那么用Miniconda建立一个3.6的python环境
代码改变世界