使用 Pickle 进行多对象序列化和反序列化
在 Python 中,pickle 模块提供了一种方便的方法来序列化和反序列化对象,但是如何实现呢?您处理多个对象?
要将多个对象保存在 pickle 文件中,您可以使用列表或元组来聚合它们。例如:
<code class="python">my_objects = [obj1, obj2, obj3] with open('objects.pkl', 'wb') as f: pickle.dump(my_objects, f)</code>
要加载对象,只需:
<code class="python">with open('objects.pkl', 'rb') as f: my_objects = pickle.load(f)</code>
pickle 模块支持存储正在腌制的项目数量,从而可以单独加载它们。然而,对于较大的数据集,将所有内容加载到内存中可能不是最佳选择。
另一种方法是使用生成器一次加载一个对象:
<code class="python">def loadall(filename): with open(filename, "rb") as f: try: while True: yield pickle.load(f) except EOFError: pass</code>
这样,仅需要时加载下一个对象,从而节省内存。
以上是如何在 Python 中使用 Pickle 序列化和反序列化多个对象?的详细内容。更多信息请关注PHP中文网其他相关文章!