阅读量:2
Python对象序列化可以通过pickle模块来实现。pickle模块提供了一种简单的持久化Python对象的方法,它将Python对象转化为一系列字节流,可以存储在文件或者通过网络传输,然后再将字节流重新转化为原来的Python对象。
以下是一个简单的示例代码,演示了如何使用pickle模块进行对象的序列化和反序列化:
import pickle # 定义一个对象 class Person: def __init__(self, name, age): self.name = name self.age = age # 序列化对象 def serialize(obj, file_path): with open(file_path, 'wb') as file: pickle.dump(obj, file) # 反序列化对象 def deserialize(file_path): with open(file_path, 'rb') as file: obj = pickle.load(file) return obj # 使用示例 p = Person('Alice', 25) serialize(p, 'person.pkl') p_deserialized = deserialize('person.pkl') print(p_deserialized.name) # 输出:Alice print(p_deserialized.age) # 输出:25
在上述代码中,我们定义了一个Person
类,然后使用pickle
模块中的dump
方法将Person
对象序列化到文件person.pkl
中。接着,我们使用pickle
模块中的load
方法从文件中反序列化出一个对象p_deserialized
,并打印出其中的属性值。
需要注意的是,在使用pickle进行对象的序列化和反序列化时,要确保读取和写入文件的模式分别为rb
和wb
,这样可以保证以二进制的形式进行读写操作。