pickle

pickle

  Python提供了pickle模块来实现序列化。

  首先,我们尝试把一个对象序列化并写入文件:

  

  pickle.dumps()方法把任意对象序列化成一个bytes,然后,就可以把这个bytes写入文件。或者用另一个方法pickle.dump()直接把对象序列化后写入一个file-like Object:

  

  看看写入的dump.txt文件,一堆乱七八糟的内容,这些都是Python保存的对象内部信息。

  当我们要把对象从磁盘读到内存时,可以先把内容读到一个bytes,然后用pickle.loads()方法反序列化出对象,也可以直接用pickle.load()方法从一个file-like Object中直接反序列化出对象。我们打开另一个Python命令行来反序列化刚才保存的对象:

  

  Pickle的问题和所有其他编程语言特有的序列化问题一样,就是它只能用于Python,并且可能不同版本的Python彼此都不兼容,因此,只能用Pickle保存那些不重要的数据,不能成功地反序列化也没关系。

原文地址:https://www.cnblogs.com/tekkaman/p/5717686.html