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

Mary-Kate Olsen
发布: 2024-11-03 19:10:29
原创
169 人浏览过

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

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!