Python 数据的 JSON 格式序列化及反序列化
liuian 2025-05-10 23:19 84 浏览
在 Python 中,将数据转换为 JSON 格式非常简单,可以使用内置的 json 模块。json 模块提供了 json.dumps() 和 json.dump() 方法,用于将 Python 对象(如字典、列表、字符串等)转换为 JSON 字符串或写入文件。
一、Python 数据的 JSON 格式序列化
1. 使用 json.dumps() 将 Python 对象转换为 JSON 字符串
json.dumps() 方法将 Python 对象转换为 JSON 格式的字符串。
示例代码:
import json
# Python 字典
data = {
"name": "John",
"age": 30,
"is_student": False,
"courses": ["Math", "Science"],
"address": {
"city": "New York",
"zipcode": "10001"
}
}
# 将 Python 对象转换为 JSON 字符串
json_string = json.dumps(data, indent=4) # indent 参数用于美化输出,缩进 4 个空格
print(json_string)
输出:
{
"name": "John",
"age": 30,
"is_student": false,
"courses": [
"Math",
"Science"
],
"address": {
"city": "New York",
"zipcode": "10001"
}
}
2. 使用 json.dump() 将 Python 对象写入 JSON 文件
json.dump() 方法将 Python 对象直接写入文件。
示例代码:
import json
# Python 字典
data = {
"name": "John",
"age": 30,
"is_student": False,
"courses": ["Math", "Science"],
"address": {
"city": "New York",
"zipcode": "10001"
}
}
# 将 Python 对象写入 JSON 文件
with open("data.json", "w") as json_file:
json.dump(data, json_file, indent=4) # indent 参数用于美化输出
文件内容(data.json):
{
"name": "John",
"age": 30,
"is_student": false,
"courses": [
"Math",
"Science"
],
"address": {
"city": "New York",
"zipcode": "10001"
}
}
3. 处理不支持的数据类型
默认情况下,json 模块只能序列化以下 Python 数据类型:
- 字典
- 列表
- 字符串
- 整数
- 浮点数
- 布尔值
- None
如果需要序列化其他数据类型(如日期、自定义对象等),可以通过 default 参数指定一个转换函数。
示例代码:
import json
from datetime import datetime
# 自定义对象
class User:
def __init__(self, name, age):
self.name = name
self.age = age
# 自定义转换函数
def custom_serializer(obj):
if isinstance(obj, datetime):
return obj.isoformat() # 将 datetime 转换为字符串
elif isinstance(obj, User):
return {"name": obj.name, "age": obj.age} # 将 User 对象转换为字典
raise TypeError(f"Type {type(obj)} not serializable")
# 数据包含自定义对象和日期
data = {
"user": User("John", 30),
"created_at": datetime.now()
}
# 使用 default 参数处理不支持的类型
json_string = json.dumps(data, default=custom_serializer, indent=4)
print(json_string)
输出:
{
"user": {
"name": "John",
"age": 30
},
"created_at": "2023-10-05T12:34:56.789012"
}
4. 其他常用参数
- indent:指定缩进空格数,用于美化输出。
- sort_keys:是否按键名排序(默认为 False)。
- ensure_ascii:是否确保输出为 ASCII 字符(默认为 True,设置为 False 可以输出非 ASCII 字符)。
示例:
json_string = json.dumps(data, indent=4, sort_keys=True, ensure_ascii=False)
总结
- 使用 json.dumps() 将 Python 对象转换为 JSON 字符串。
- 使用 json.dump() 将 Python 对象写入 JSON 文件。
- 通过 default 参数处理不支持的数据类型。
- 使用 indent、sort_keys 等参数控制输出格式。
JSON 是 Web 开发中常用的数据交换格式,Python 的 json 模块提供了简单易用的工具来处理 JSON 数据。
二、Python 的 JSON 字符串反序列化
在 Python 中,将 JSON 字符串反序列化为 Python 对象(如字典、列表等)也非常简单,可以使用内置的 json 模块。json 模块提供了 json.loads() 和 json.load() 方法,用于将 JSON 字符串或文件内容转换为 Python 对象。
1. 使用 json.loads() 将 JSON 字符串转换为 Python 对象
json.loads() 方法将 JSON 格式的字符串转换为 Python 对象(通常是字典或列表)。
示例代码:
import json
# JSON 字符串
json_string = '''
{
"name": "John",
"age": 30,
"is_student": false,
"courses": ["Math", "Science"],
"address": {
"city": "New York",
"zipcode": "10001"
}
}
'''
# 将 JSON 字符串转换为 Python 对象
data = json.loads(json_string)
print(data)
print(type(data)) # 输出 <class 'dict'>
输出:
{
'name': 'John',
'age': 30,
'is_student': False,
'courses': ['Math', 'Science'],
'address': {
'city': 'New York',
'zipcode': '10001'
}
}
2. 使用 json.load() 从 JSON 文件读取并转换为 Python 对象
json.load() 方法从文件中读取 JSON 数据并转换为 Python 对象。
示例代码:
假设有一个 data.json 文件,内容如下:
{
"name": "John",
"age": 30,
"is_student": false,
"courses": ["Math", "Science"],
"address": {
"city": "New York",
"zipcode": "10001"
}
}
读取并解析文件:
import json
# 从 JSON 文件中读取并转换为 Python 对象
with open("data.json", "r") as json_file:
data = json.load(json_file)
print(data)
print(type(data)) # 输出 <class 'dict'>
输出:
{
'name': 'John',
'age': 30,
'is_student': False,
'courses': ['Math', 'Science'],
'address': {
'city': 'New York',
'zipcode': '10001'
}
}
3. 处理复杂数据类型
默认情况下,json 模块会将 JSON 数据转换为以下 Python 数据类型:
- JSON 对象 → Python 字典
- JSON 数组 → Python 列表
- JSON 字符串 → Python 字符串
- JSON 数字 → Python 整数或浮点数
- JSON true/false → Python True/False
- JSON null → Python None
如果需要将 JSON 数据转换为自定义对象,可以使用 object_hook 参数。
示例代码:
import json
# JSON 字符串
json_string = '''
{
"name": "John",
"age": 30,
"is_student": false,
"address": {
"city": "New York",
"zipcode": "10001"
}
}
'''
# 自定义类
class User:
def __init__(self, name, age, is_student, address):
self.name = name
self.age = age
self.is_student = is_student
self.address = address
def __repr__(self):
return f"User(name={self.name}, age={self.age}, is_student={self.is_student}, address={self.address})"
# 自定义转换函数
def custom_deserializer(dct):
if "name" in dct and "age" in dct: # 判断是否为 User 对象
return User(dct["name"], dct["age"], dct["is_student"], dct["address"])
return dct
# 使用 object_hook 参数处理自定义对象
data = json.loads(json_string, object_hook=custom_deserializer)
print(data)
输出:
User(name=John, age=30, is_student=False, address={'city': 'New York', 'zipcode': '10001'})
4. 其他注意事项
- JSON 字符串格式必须正确:如果 JSON 字符串格式不正确(例如缺少引号、括号不匹配等),会抛出 json.JSONDecodeError 异常。
- 处理日期和时间:JSON 本身不支持日期和时间类型,通常需要将日期时间转换为字符串后再反序列化。
示例:处理日期时间
import json
from datetime import datetime
# JSON 字符串
json_string = '''
{
"event": "Conference",
"date": "2023-10-05T12:34:56"
}
'''
# 自定义转换函数
def custom_deserializer(dct):
if "date" in dct:
dct["date"] = datetime.fromisoformat(dct["date"]) # 将字符串转换为 datetime 对象
return dct
# 使用 object_hook 参数处理日期时间
data = json.loads(json_string, object_hook=custom_deserializer)
print(data)
输出:
{
'event': 'Conference',
'date': datetime.datetime(2023, 10, 5, 12, 34, 56)
}
总结
- 使用 json.loads() 将 JSON 字符串转换为 Python 对象。
- 使用 json.load() 从 JSON 文件读取并转换为 Python 对象。
- 使用 object_hook 参数处理自定义对象或复杂数据类型。
- JSON 是 Web 开发中常用的数据交换格式,Python 的 json 模块提供了简单易用的工具来处理 JSON 数据。
好了,此文足已能让你无忧于 Python 数据的 JSON 格式序列化及反序列化了。
爱学习的小伙伴,关注不迷路哟~
相关推荐
- Python生态下的微服务框架FastAPI
-
FastAPI是什么FastAPI是一个用于构建API的web框架,使用Python并基于标准的Python类型提示。与flask相比有什么优势高性能:得益于uvloop,可达到与...
- SpringBoot:如何解决跨域问题,详细方案和示例代码
-
跨域问题在前端开发中经常会遇到,特别是在使用SpringBoot框架进行后端开发时。解决跨域问题的方法有很多,我将为你提供一种详细的方案,包含示例代码。首先,让我们了解一下什么是跨域问题。跨域是指在...
- 使用Nginx轻松搞定跨域问题_使用nginx轻松搞定跨域问题的方法
-
跨域问题(Cross-OriginResourceSharing,简称CORS)是由浏览器的同源策略引起的。同源策略指的是浏览器限制来自不同源(协议、域名、端口)的JavaScript对资源的...
- spring boot过滤器与拦截器的区别
-
有小伙伴使用springboot开发多年,但是对于过滤器和拦截器的主要区别依然傻傻分不清。今天就对这两个概念做一个全面的盘点。定义与作用范围过滤器(Filter):过滤器是一种可以动态地拦截、处理和...
- nginx如何配置跨域_nginx配置跨域访问
-
要在Nginx中配置跨域,可以使用add_header指令来添加Access-Control-Allow-*头信息,如下所示:location/api{if($reques...
- 解决跨域问题的8种方法,含网关、Nginx和SpringBoot~
-
跨域问题是浏览器为了保护用户的信息安全,实施了同源策略(Same-OriginPolicy),即只允许页面请求同源(相同协议、域名和端口)的资源,当JavaScript发起的请求跨越了同源策略,...
- 图解CORS_图解数学
-
CORS的全称是Cross-originresourcesharing,中文名称是跨域资源共享,是一种让受限资源能够被其他域名的页面访问的一种机制。下图描述了CORS机制。一、源(Orig...
- CORS 幕后实际工作原理_cors的工作原理
-
跨域资源共享(CORS)是Web浏览器实施的一项重要安全机制,用于保护用户免受潜在恶意脚本的攻击。然而,这也是开发人员(尤其是Web开发新手)感到沮丧的常见原因。小编在此将向大家解释它存在...
- 群晖无法拉取Docker镜像?最稳定的方法:搭建自己的加速服务!
-
因为未知的原因,国内的各大DockerHub镜像服务器无法使用,导致在使用群晖时无法拉取镜像构建容器。网上大部分的镜像加速服务都是通过Cloudflare(CF)搭建的,为什么都选它呢?因为...
- Sa-Token v1.42.0 发布,新增 API Key、TOTP 验证码等能力
-
Sa-Token是一款免费、开源的轻量级Java权限认证框架,主要解决:登录认证、权限认证、单点登录、OAuth2.0、微服务网关鉴权等一系列权限相关问题。目前最新版本v1.42.0已...
- NGINX常规CORS错误解决方案_nginx配置cors
-
CORS错误CORS(Cross-OriginResourceSharing,跨源资源共享)是一种机制,它使用额外的HTTP头部来告诉浏览器允许一个网页运行的脚本从不同于它自身来源的服务器上请求资...
- Spring Boot跨域问题终极解决方案:3种方案彻底告别CORS错误
-
引言"接口调不通?前端同事又双叒叕在吼跨域了!""明明Postman能通,浏览器却报OPTIONS403?""生产环境跨域配置突然失效,凌晨3点被夺命连环Ca...
- SpringBoot 项目处理跨域的四种技巧
-
上周帮一家公司优化代码时,顺手把跨域的问题解决了,这篇文章,我们聊聊SpringBoot项目处理跨域的四种技巧。1什么是跨域我们先看下一个典型的网站的地址:同源是指:协议、域名、端口号完全相...
- Spring Cloud入门看这一篇就够了_spring cloud使用教程
-
SpringCloud微服务架构演进单体架构垂直拆分分布式SOA面向服务架构微服务架构服务调用方式:RPC,早期的webservice,现在热门的dubbo,都是RPC的典型代表HTTP,HttpCl...
- 前端程序员:如何用javascript开发一款在线IDE?
-
前言3年前在AWSre:Invent大会上AWS宣布推出Cloud9,用于在云端编写、运行和调试代码,它可以直接运行在浏览器中,也就是传说中的WebIDE。3年后的今天随着国内云计算的发...
- 一周热门
-
-
【验证码逆向专栏】vaptcha 手势验证码逆向分析
-
Python实现人事自动打卡,再也不会被批评
-
Psutil + Flask + Pyecharts + Bootstrap 开发动态可视化系统监控
-
一个解决支持HTML/CSS/JS网页转PDF(高质量)的终极解决方案
-
再见Swagger UI 国人开源了一款超好用的 API 文档生成框架,真香
-
网页转成pdf文件的经验分享 网页转成pdf文件的经验分享怎么弄
-
C++ std::vector 简介
-
飞牛OS入门安装遇到问题,如何解决?
-
系统C盘清理:微信PC端文件清理,扩大C盘可用空间步骤
-
10款高性能NAS丨双十一必看,轻松搞定虚拟机、Docker、软路由
-
- 最近发表
- 标签列表
-
- python判断字典是否为空 (50)
- crontab每周一执行 (48)
- aes和des区别 (43)
- bash脚本和shell脚本的区别 (35)
- canvas库 (33)
- dataframe筛选满足条件的行 (35)
- gitlab日志 (33)
- lua xpcall (36)
- blob转json (33)
- python判断是否在列表中 (34)
- python html转pdf (36)
- 安装指定版本npm (37)
- idea搜索jar包内容 (33)
- css鼠标悬停出现隐藏的文字 (34)
- linux nacos启动命令 (33)
- gitlab 日志 (36)
- adb pull (37)
- python判断元素在不在列表里 (34)
- python 字典删除元素 (34)
- vscode切换git分支 (35)
- python bytes转16进制 (35)
- grep前后几行 (34)
- hashmap转list (35)
- c++ 字符串查找 (35)
- mysql刷新权限 (34)