Python pickle 关于存储以 “w”还是“wb”方式

1 首先pickle是提供python对象序列化的工具

2 pickle提供的序列化是字符串级别的

3 pickle序列化的结果是一个可以通过文本预览的序列化的对象

总结起来就是:得以“w”的方式写入文件

py2.7

options = [1,2,3,4,5,6,7,8,9,10]
print(options)
print("write as str")
with open("str.txt",'w') as f:
    pickle.dump(options,f)
f.close()
print("write as wb")
with open("wb.txt",'wb') as f:
    pickle.dump(options,f)
f.close()

接下来看看两个文件的区别

$ md5sum str.txt wb.txt 
fd57223c5c67abda1dba90e06bf9acfb  str.txt
fd57223c5c67abda1dba90e06bf9acfb  wb.txt

py3
执行同样的文件, 得到了以下的结果

write as str
Traceback (most recent call last):
  File "tmp.py", line 61, in 
    pickle.dump(options,f)
TypeError: write() argument must be str, not bytes

看起来py3对文件类型进行了检查,及时抛出了错误

大家不要被网上很多教程给弄混了,最重要的还是自己动手验证

总结起来就是,pickle 只能是序列化成了字符串,不能保存成二进制文件,为了保险和安全起见,请在是用pickle.dump 的时候 文件参数使用‘w’方式载入。

你可能感兴趣的:(python)