首页  >  文章  >  后端开发  >  如何在 Python 中使用 Pickle 序列化和反序列化多个对象?

如何在 Python 中使用 Pickle 序列化和反序列化多个对象?

Mary-Kate Olsen
Mary-Kate Olsen原创
2024-11-03 19:10:29162浏览

How to Serialize and Deserialize Multiple Objects with Pickle in Python?

使用 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中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn