Python序列化:pickle与json对比解析
时间:2026-01-27 21:30:45 151浏览 收藏
大家好,我们又见面了啊~本文《Python序列化方法:pickle与json详解》的内容中将会涉及到等等。如果你正在学习文章相关知识,欢迎关注我,以后会给大家带来更多文章相关文章,希望我们能一起进步!下面就开始本文的正式内容~
Python序列化选pickle或json取决于场景:pickle支持任意Python对象但不安全、不可跨语言;json安全、跨语言但仅支持基础类型。内部临时存储用pickle,外部交互用json。

Python中序列化对象主要有 pickle 和 json 两种方式,它们用途不同、限制不同、安全性也不同。选错方法可能导致数据无法还原、程序崩溃,甚至被恶意利用。
pickle:Python专属的二进制序列化
pickle 是 Python 原生支持的序列化模块,能保存几乎任意 Python 对象(函数、类实例、嵌套结构等),但只适用于 Python 环境内部使用。
- 生成的是二进制数据(也可用文本协议,但默认不推荐),不能直接阅读或跨语言交换
- 反序列化时会执行任意代码(如构造器、
__setstate__),绝不能加载不可信来源的 pickle 数据 - 不同 Python 版本间兼容性有限,高版本 pickle 的数据可能无法被低版本读取
- 常用方法:
pickle.dump(obj, file)、pickle.load(file)、pickle.dumps(obj)、pickle.loads(bytes)
json:轻量、安全、跨语言的文本序列化
json 模块将数据转为标准 JSON 格式(纯文本),天然支持 Web 交互和多语言协作,但只支持基础数据类型。
- 仅支持
dict、list、str、int、float、bool、None这几种类型;自定义类、函数、datetime、bytes 等需手动转换 - 天生安全:反序列化不会执行代码,适合处理外部输入(如 API 返回、用户上传)
- 生成结果人类可读,便于调试和日志记录
- 常用方法:
json.dump(obj, file)、json.load(file)、json.dumps(obj)、json.loads(str)
怎么选?看场景和数据类型
如果只是临时保存 Python 内部状态(如缓存、进程间传递),且完全控制数据来源,用 pickle 更省事;如果要存配置、传 API、写日志、或与前端/其他语言交互,必须用 json。
- 想保存一个
datetime?json默认不支持,得先转成字符串(如dt.isoformat()),读取时再解析 - 想保存一个带方法的类实例?
json不行,pickle可以,但要注意版本和安全性 - 从网页表单接收 JSON 数据?只能用
json.loads(),用pickle.loads()会报错甚至引发漏洞
小技巧:让 json 支持更多类型
通过 default 参数和自定义 JSONEncoder,可以让 json 处理常见扩展类型。
- 例如把
datetime自动转为 ISO 字符串:json.dumps(obj, default=str)(简单粗暴,适用多数情况) - 更精确的做法是继承
json.JSONEncoder,重写default方法,对不同类型做针对性处理 - 反序列化时没有内置机制,需在业务逻辑里手动识别字段并转换(如检测
"created_at"字段后调用datetime.fromisoformat())
好了,本文到此结束,带大家了解了《Python序列化:pickle与json对比解析》,希望本文对你有所帮助!关注golang学习网公众号,给大家分享更多文章知识!
相关阅读
更多>
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
最新阅读
更多>
-
160 收藏
-
194 收藏
-
125 收藏
-
308 收藏
-
437 收藏
-
312 收藏
-
482 收藏
-
268 收藏
-
103 收藏
-
346 收藏
-
418 收藏
-
348 收藏
课程推荐
更多>
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习