1、pickle替换了cPickle
pickle读文件时可能存在的编码问题:
import gzip
import pickle
# 使用with结构避免手动的文件关闭操作
with gzip.open('./mnist.pkl.gz', 'rb') as f:
training_data, validation_data, test_data = pickle.load(f)
如果沿用python 2.x的做法,如上所示,而不做任何编码格式上的设置,直接运行,编译器会提示如下错误:
UnicodeDecodeError: 'ascii' codec can't decode byte 0x90 in position 614: ordinal not in range(128)
解决方案:
with gzip.open('./mnist.pkl.gz', 'rb') as f:
training_data, validation_data, test_data = pickle.load(f, encoding='latin1')
2、len(zip对象)报错
报错信息:
TypeError: object of type 'zip' has no len()
对于zip对象的维度信息可以通过先将其转换为list, 然后求维度信息。
如一个result对象为zip对象, 先将其转换为list对象。
result = list(result);
len(result)
len(result[0])
3、input替换了raw_input
- 例如:从标准输入中读入两个变量10 23到a b中:
# 两个字符串
a,b = input().split()
# 两个数
a,b = map(int,input().split())