不能pickle文件对象,因其依赖操作系统文件描述符,不具备可移植性。应保存文件内容或路径:读取内容后用pickle序列化数据,或仅保存路径字符串供后续使用。

Python 中的 pickle 模块用于将 Python 对象序列化为字节流,以便保存到文件或在网络中传输。但需要注意的是,不能直接使用 pickle 序列化文件对象本身(比如通过 open() 打开的文件句柄),因为文件对象是与操作系统资源相关联的运行时资源,无法被安全地保存和恢复。
当你尝试对一个打开的文件对象执行 pickle.dumps(file_obj) 时,会抛出异常:
这是因为:
如果你希望保存“文件相关内容”,应该转换思路:不是保存文件对象,而是保存其内容或路径信息。
立即学习“Python免费学习笔记(深入)”;
本文档主要讲述的是JSON.NET 简单的使用;JSON.NET使用来将.NET中的对象转换为JSON字符串(序列化),或者将JSON字符串转换为.NET中已有类型的对象(反序列化?)。希望本文档会给有需要的朋友带来帮助;感兴趣的朋友可以过来看看
0
示例:保存并恢复文本内容
import pickle根据实际需求选择合适方式:
基本上就这些。pickle 很强大,但只适用于可序列化的 Python 对象,不包括运行中的 I/O 资源。理解这一点能避免常见陷阱。
以上就是Python 使用 pickle 序列化文件对象的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号