在python3.x中,python2.x的cPickle模块已经替换成了pickle模块,因此在python3.x中加载由python2.x的cPickle模块保存的文件时可以使用python3.x中的pickle.load(…)函数。
需要注意的是,pickle.load(…)函数其中一个参数为encoding,默认值为’ASCII’,如此使用默认值加载文件,会出现如下错误提示:
UnicodeDecodeError: ‘ascii’ codec can’t decode byte 0x90 in position 614: ordinal not in range(128)
因此,需要修改encoding参数,将encoding修改为’latin1’即可.
【函数声明】只展示必须的两个参数
pickle.load(file, encoding=‘ASCII’, …)
file: 文件对象
encoding: 文件的编码方式
【示例】
In [1]: import pickle
In [2]: f = open('C:\\mnist.pkl', 'rb')
# 直接以默认encoding参数
In [3]: res = pickle.load(f)
UnicodeDecodeError: 'ascii' codec can't decode byte 0x90 in position 614: ordinal not in range(128)
In [4]: f.close()
In [5]: f = open('C:\\mnist.pkl', 'rb')
In [6]: res = pickle.load(f, encoding='latin1')
In [7]: f.close()
In [8]: type(res)
Out[8]: tuple