news 2026/6/23 18:19:56

Python中的JSON处理(标准库)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Python中的JSON处理(标准库)

一、什么是JSON?

JSON(JavaScript Object Notation)是一种基于文本的开放标准,用于表示结构化数据。它采用键值对的形式组织数据,支持以下基本数据类型:

  • 字符串(string)
  • 数字(number)
  • 布尔值(true / false)
  • 空值(null)
  • 对象(object,即键值对集合)
  • 数组(array,即有序列表)

例如,一个简单的 JSON 数据如下:

{ "name": "张三", "age": 25, "is_student": true, "hobbies": ["读书", "游泳"], "address": null }

二、Python中的json模块

Python 的标准库json提供了将 Python 对象序列化为 JSON 字符串,以及将 JSON 字符串反序列化为 Python 对象的功能。该模块无需安装,直接导入即可使用:

import json

主要函数

函数功能
json.dumps(obj)将 Python 对象转换为 JSON 字符串
json.loads(s)将 JSON 字符串解析为 Python 对象
json.dump(obj, file)将 Python 对象写入文件(以 JSON 格式)
json.load(file)从文件读取 JSON 数据并解析为 Python 对象

三、数据类型映射关系

Python 与 JSON 在数据类型上存在一定的映射关系:

Python 类型JSON 类型
dictobject
list,tuplearray
strstring
int,floatnumber
Truetrue
Falsefalse
Nonenull

注意:Python 中的tuple会被转换为 JSON 的array,但反向解析时会变成list


四、基本用法示例

1. 序列化:Python对象 → JSON字符串(dumps)

import json data = { "name": "李四", "age": 30, "is_employee": True, "skills": ["Python", "Django", "Flask"], "address": None } # 转换为JSON字符串 json_str = json.dumps(data, ensure_ascii=False, indent=2) print(json_str)

输出结果:

{ "name": "李四", "age": 30, "is_employee": true, "skills": [ "Python", "Django", "Flask" ], "address": null }

参数说明:

  • ensure_ascii=False:允许非ASCII字符(如中文)正常显示,否则会转义。
  • indent=2:美化输出,使用2个空格缩进,便于阅读。

2. 反序列化:JSON字符串 → Python对象(loads)

json_string = ''' { "title": "Python入门教程", "pages": 256, "available": true, "tags": ["编程", "学习"] } ''' data = json.loads(json_string) print(type(data)) # <class 'dict'> print(data['title']) # Python入门教程

3. 写入JSON文件(dump)

with open('data.json', 'w', encoding='utf-8') as f: json.dump(data, f, ensure_ascii=False, indent=4)

这会将data对象写入名为data.json的文件中,并以 UTF-8 编码保存,支持中文。


4. 读取JSON文件(load)

with open('data.json', 'r', encoding='utf-8') as f: loaded_data = json.load(f) print(loaded_data)

五、常见问题与注意事项

1. 处理中文乱码

默认情况下,json.dumps()会将非 ASCII 字符转义(如\u4e2d\u6587),需设置ensure_ascii=False才能正确显示中文。

2. 自定义对象无法直接序列化

Python 中自定义类的对象不能直接被json序列化。例如:

class Person: def __init__(self, name, age): self.name = name self.age = age p = Person("王五", 28) # json.dumps(p) # 报错:Object of type Person is not JSON serializable

解决方法:提供自定义的序列化函数或继承JSONEncoder

方法一:使用default参数
def person_serializer(obj): if isinstance(obj, Person): return {'name': obj.name, 'age': obj.age} raise TypeError(f"Object of type {type(obj)} is not JSON serializable") json_str = json.dumps(p, default=person_serializer, ensure_ascii=False, indent=2) print(json_str)
方法二:自定义 JSONEncoder
class PersonEncoder(json.JSONEncoder): def default(self, obj): if isinstance(obj, Person): return {'name': obj.name, 'age': obj.age} return super().default(obj) json_str = json.dumps(p, cls=PersonEncoder, ensure_ascii=False, indent=2) print(json_str)

六、实际应用场景

  1. API 接口通信
    Web 开发中,客户端与服务器常通过 JSON 传输数据。Python 后端可使用json模块解析请求体或构造响应内容。

  2. 配置文件存储
    使用.json文件保存程序配置,如数据库连接信息、用户偏好设置等。

  3. 日志记录与数据导出
    将结构化数据以 JSON 格式保存,便于后续分析或迁移。

  4. 跨语言数据交换
    JSON 是语言无关的格式,Python 生成的 JSON 可被 JavaScript、Java、Go 等语言解析。


七、性能建议

  • 对于大量数据操作,避免频繁调用dumps/loads,可考虑批量处理。
  • 若需更高性能,可使用第三方库如ujsonorjson(非标准库,但兼容性好)。

总结

Python 的json模块是一个功能强大且简单易用的标准库,能够高效地完成 JSON 数据的序列化与反序列化。掌握其基本用法对于从事 Web 开发、数据处理或自动化脚本编写的开发者来说至关重要。

通过本文的学习,你应该已经掌握了:

  • 如何使用dumpsloads进行字符串级别的转换;
  • 如何使用dumpload操作 JSON 文件;
  • 如何处理中文、美化输出;
  • 如何扩展支持自定义对象;
  • 了解常见的使用场景与最佳实践。

📌参考文档
Python 官方文档 - json 模块

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 19:59:23

AI产品经理必修课:拆解大模型落地的关键能力与实战技巧

文章从四大维度系统阐述了AI产品经理的必备能力&#xff1a;两大定律&#xff08;AI能力定律和AI提效定律&#xff09;强调判断力的重要性&#xff1b;五要素&#xff08;业务人员参与、AI能力认知、编程能力、小处着手、老板支持&#xff09;确保大模型成功落地&#xff1b;技…

作者头像 李华
网站建设 2026/6/19 14:09:46

CodeArts Doer代码智能体

什么是CodeArts Doer代码智能体 CodeArts Doer代码智能体是一款集代码大模型、AI IDE、代码Agent为一体的智能编码产品。面向代码生成、研发知识问答、单元测试用例生成、代码解释、代码注释、代码调试、代码翻译、代码检查、代码优化等场景功能&#xff0c;为开发者提高研发效…

作者头像 李华
网站建设 2026/6/10 15:38:36

SpringMVC的处理流程

一张图搞懂 SpringMVC 完整请求流程&#xff1a;从浏览器到页面响应的全链路拆解作为 Java 后端开发者&#xff0c;SpringMVC 的请求处理流程是日常开发的核心逻辑&#xff0c;但很多时候我们只知其然不知其所以然。今天&#xff0c;我就通过这张经典的 SpringMVC 处理流程图&a…

作者头像 李华
网站建设 2026/6/15 13:37:25

YOLOv8科研级轻量化升级:基于SOTA ADown的高效下采样设计

文章目录 【YOLOv8科研级轻量化】集成SOTA轻量下采样ADown,让模型下采样效率跃升20%+ 一、为什么要做这个改进? 二、先搞懂原理:ADown的设计逻辑 1. ADown的核心设计 2. 替换YOLOv8下采样的思路 三、动手改造YOLOv8:从代码到训练的完整路径 步骤1:实现ADown的核心代码 步骤…

作者头像 李华
网站建设 2026/6/22 0:43:27

一文吃透图像超分辨率:SRResNet核心原理与实战实现

文章目录 一、 引言:揭秘图像超分辨率的奥秘 二、 SRResNet算法原理:深度学习赋能图像超分辨率 1. 深度残差网络:突破传统网络的瓶颈 1.1 残差学习的核心思想 1.2 SRResNet中的深度残差模块 2. 子像素卷积:高效且可学习的上采样方案 2.1 子像素卷积的优势 2.2 子像素卷积的…

作者头像 李华