Python3入门之JSON数据解析全面学习教程

 更新时间:2025年11月28日 09:31:15   作者:xcLeigh  
Python作为一门简洁、易读、功能强大的编程语言,其基础语法是入门学习的核心,本文将为大家全面讲解JSON数据解析的相关知识,需要的可以参考下

前言

Python作为一门简洁、易读、功能强大的编程语言,其基础语法是入门学习的核心。掌握好基础语法,能为后续的编程实践打下坚实的基础。本文将全面讲解Python3的基础语法知识,适合编程初学者系统学习。Python以其简洁优雅的语法和强大的通用性,成为当今最受欢迎的编程语言。本专栏旨在系统性地带你从零基础入门到精通Python核心。无论你是零基础小白还是希望进阶的专业开发者,都将通过清晰的讲解、丰富的实例和实战项目,逐步掌握语法基础、核心数据结构、函数与模块、面向对象编程、文件处理、主流库应用(如数据分析、Web开发、自动化)以及面向对象高级特性,最终具备独立开发能力和解决复杂问题的思维,高效应对数据分析、人工智能、Web应用、自动化脚本等广泛领域的实际需求。

在当今的数据交换场景中,JSON(JavaScript Object Notation)凭借其轻量级、易读易写的特性,成为了前后端交互、API数据传输的主流格式。而Python作为数据分析和后端开发的热门语言,内置了json模块来高效处理JSON数据。本文将从JSON基础概念入手,详细讲解Python3中json模块的核心函数用法,结合实例帮助你快速掌握JSON数据的编解码技巧。

一、JSON基础:为什么它如此重要

JSON是一种基于文本的轻量级数据交换格式,它源于JavaScript,但如今已成为跨语言、跨平台的数据交换标准。相比于XML,JSON语法更简洁、解析速度更快,非常适合传输结构化数据(如用户信息、接口返回结果等)。

如果你对JSON语法尚不熟悉,可以先了解其核心数据类型:

  • 对象(对应Python的字典):用{key: value}表示,键值对之间用逗号分隔
  • 数组(对应Python的列表):用[value1, value2, ...]表示
  • 基本类型:字符串(双引号包裹)、数字(整数/浮点数)、布尔值(true/false)、空值(null

二、Python3json模块核心函数

Python3的标准库json模块提供了4个核心函数,分别用于字符串级别的编解码文件级别的编解码,覆盖了绝大多数JSON处理场景。

函数用途函数名核心作用
Python数据编码为JSON字符串json.dumps()将Python原生数据类型转换为JSON格式字符串
JSON字符串解码为Python数据json.loads()将JSON格式字符串转换为Python原生数据类型
Python数据写入JSON文件json.dump()将Python数据直接写入文件(JSON格式)
从JSON文件读取Python数据json.load()从JSON文件中读取数据并转换为Python类型

三、关键知识点:Python与JSON类型对应关系

在编解码过程中,Python原生类型与JSON类型会自动转换,理解对应关系是避免数据异常的关键。

1. Python编码为JSON的类型映射

当使用json.dumps()json.dump()时,Python数据会按照以下规则转换为JSON类型:

Python原生类型转换后的JSON类型示例
dict(字典)object(对象){'name': 'xcLeigh'} → {"name": "xcLeigh"}
list(列表)、tuple(元组)array(数组)[1, 2, 3] → [1,2,3];(1,2,3) → [1,2,3]
str(字符串)string(字符串)"Python" → "Python"
int/float(整数/浮点数)number(数字)100 → 100;3.14 → 3.14
True(布尔值)trueTrue → true
False(布尔值)falseFalse → false
None(空值)nullNone → null

2. JSON解码为Python的类型映射

当使用json.loads()json.load()时,JSON类型会按照以下规则转换为Python类型:

JSON类型转换后的Python类型示例
object(对象)dict(字典){"no": 1} → {'no': 1}
array(数组)list(列表)["xcLeigh", "Python"] → ['xcLeigh', 'Python']
string(字符串)str(字符串)"https://xcleigh.blog.csdn.net/" → "https://xcleigh.blog.csdn.net/"
number(int)(整数)int(整数)10 → 10
number(real)(浮点数)float(浮点数)3.14 → 3.14
trueTruetrue → True
falseFalsefalse → False
nullNonenull → None

四、实战案例:从字符串到文件的完整操作

理论结合实践才能快速掌握,下面通过3个递进的案例,演示json模块的核心用法。

案例1:Python数据编码为JSON字符串(json.dumps())

将Python字典(最常用的结构化数据类型)转换为JSON字符串,方便后续传输或存储。

#!/usr/bin/python3
import json

# 1. 定义Python字典(原始数据)
data = {
    'no': 1,
    'name': 'xcLeigh',
    'url': 'https://xcleigh.blog.csdn.net/',
    'is_active': True,
    'tags': ['Python', 'JSON', '教程'],
    'score': 98.5,
    'extra_info': None
}

# 2. 使用json.dumps()编码为JSON字符串
json_str = json.dumps(data)

# 3. 打印结果对比
print("Python原始数据(字典类型):", repr(data))
print("JSON字符串(类型):", json_str)
print("JSON字符串的类型:", type(json_str))  # 输出 <class 'str'>

运行结果

Python原始数据(字典类型): {'no': 1, 'name': 'xcLeigh', 'url': 'https://xcleigh.blog.csdn.net/', 'is_active': True, 'tags': ['Python', 'JSON', '教程'], 'score': 98.5, 'extra_info': None}
JSON字符串(类型): {"no": 1, "name": "xcLeigh", "url": "https://xcleigh.blog.csdn.net/", "is_active": true, "tags": ["Python", "JSON", "教程"], "score": 98.5, "extra_info": null}
JSON字符串的类型: <class 'str'>

关键说明

  • Python的True转换为JSON的trueNone转换为null(JSON语法要求小写)
  • Python字典的键是字符串时,JSON字符串的键会自动用双引号包裹(JSON键必须是双引号字符串)

案例2:JSON字符串解码为Python数据(json.loads())

将API返回的JSON字符串(或前端传递的JSON数据)转换为Python字典,方便后续数据处理(如提取字段、计算等)。

#!/usr/bin/python3
import json

# 1. 模拟一个JSON字符串(例如API返回结果)
json_str = '''
{
    "no": 1,
    "name": "xcLeigh",
    "url": "https://xcleigh.blog.csdn.net/",
    "is_active": true,
    "tags": ["Python", "JSON", "教程"],
    "score": 98.5,
    "extra_info": null
}
'''

# 2. 使用json.loads()解码为Python字典
data = json.loads(json_str)

# 3. 提取并使用数据
print("解码后的Python数据类型:", type(data))  # 输出 <class 'dict'>
print("网站名称:", data['name'])           # 输出 xcLeigh
print("网站URL:", data['url'])            # 输出 https://xcleigh.blog.csdn.net/
print("是否活跃:", data['is_active'])     # 输出 True
print("标签列表:", data['tags'][0])       # 输出 Python(提取列表第一个元素)

运行结果

解码后的Python数据类型: <class 'dict'>
网站名称: xcLeigh
网站URL:https://xcleigh.blog.csdn.net/
是否活跃: True
标签列表: Python

关键说明

  • JSON字符串中的true会转换为Python的Truenull转换为None
  • 解码后的数据可以直接用Python字典的语法操作(如data['key']提取值)

案例3:Python数据与JSON文件的交互(json.dump()/json.load())

当需要持久化存储JSON数据(如配置文件、日志数据)时,直接使用json.dump()json.load()操作文件,无需手动处理字符串写入/读取。

步骤1:将Python数据写入JSON文件(json.dump())

#!/usr/bin/python3
import json

# 1. 定义Python数据
data = {
    'no': 1,
    'name': 'xcLeigh',
    'url': 'https://xcleigh.blog.csdn.net/',
    'tags': ['Python', 'JSON']
}

# 2. 使用with语句打开文件,自动管理文件关闭
with open('data.json', 'w', encoding='utf-8') as f:
    # json.dump(数据, 文件对象)
    json.dump(data, f, ensure_ascii=False, indent=4)

print("JSON数据已成功写入data.json文件")

参数说明

  • ensure_ascii=False:允许写入非ASCII字符(如中文),避免乱码
  • indent=4:格式化输出,缩进4个空格,增强文件可读性

运行后会生成data.json文件,内容如下:

{
    "no": 1,
    "name": "xcLeigh",
    "url": "https://xcleigh.blog.csdn.net/",
    "tags": [
        "Python",
        "JSON"
    ]
}

步骤2:从JSON文件读取数据(json.load())

#!/usr/bin/python3
import json

# 1. 使用with语句读取文件
with open('data.json', 'r', encoding='utf-8') as f:
    # json.load(文件对象):读取文件并解码为Python数据
    data = json.load(f)

# 2. 使用读取到的数据
print("从文件读取的Python数据:", data)
print("网站名称:", data['name'])
print("标签数量:", len(data['tags']))

运行结果

从文件读取的Python数据: {'no': 1, 'name': 'xcLeigh', 'url': 'https://xcleigh.blog.csdn.net/', 'tags': ['Python', 'JSON']}
网站名称: xcLeigh
标签数量: 2

五、常见问题与注意事项

数据类型不匹配错误:若Python数据中包含json模块不支持的类型(如datetime对象、自定义类实例),直接编码会报错。解决方案:自定义default参数(如json.dumps(data, default=str)将不支持的类型转为字符串)。

文件编码问题:写入/读取JSON文件时,务必指定encoding='utf-8',否则中文等非ASCII字符可能出现乱码。

dumpsdumploadsload的区别

  • s的函数(dumps/loads):操作字符串,适用于内存中的数据处理(如API交互)。
  • 不带s的函数(dump/load):操作文件对象,适用于文件持久化存储。

到此这篇关于Python3入门之JSON数据解析全面学习教程的文章就介绍到这了,更多相关Python3 JSON数据解析内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • python逆向微信指数爬取实现步骤

    python逆向微信指数爬取实现步骤

    这篇文章主要为大家介绍了python逆向微信指数爬取的实现步骤,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步早日升职加薪
    2022-02-02
  • 解决Python2.7中IDLE启动没有反应的问题

    解决Python2.7中IDLE启动没有反应的问题

    今天小编就为大家分享一篇解决Python2.7中IDLE启动没有反应的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-11-11
  • 详解Python查找谁删了你的微信

    详解Python查找谁删了你的微信

    微信好友长时间不联系就可能被对方删除,但是微信也不会主动通知你。那么我们就来用python写一个工具查验一下谁删除了你的微信
    2022-02-02
  • Python Selenium网页自动化利器使用详解

    Python Selenium网页自动化利器使用详解

    这篇文章主要为大家介绍了使用Python Selenium实现网页自动化示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-12-12
  • 如何基于Python制作有道翻译小工具

    如何基于Python制作有道翻译小工具

    这篇文章主要介绍了如何基于Python制作有道翻译小工具,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-12-12
  • python Matplotlib底图中鼠标滑过显示隐藏内容的实例代码

    python Matplotlib底图中鼠标滑过显示隐藏内容的实例代码

    这篇文章主要介绍了python Matplotlib底图中鼠标滑过显示隐藏内容,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-07-07
  • python3 面向对象__类的内置属性与方法的实例代码

    python3 面向对象__类的内置属性与方法的实例代码

    这篇文章主要介绍了python3 面向对象__类的内置属性与方法的实例代码,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
    2018-11-11
  • python最小生成树kruskal与prim算法详解

    python最小生成树kruskal与prim算法详解

    这篇文章主要为大家详细介绍了python最小生成树kruskal与prim算法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-01-01
  • selenium鼠标操作实战案例详解

    selenium鼠标操作实战案例详解

    在实际场景中,会有单击、长时间单击、双击、右键、拖拽等鼠标操作,selenium提供了名为ActionChains的类来处理这些操作,下面这篇文章主要给大家介绍了关于selenium鼠标操作实战案例的相关资料,需要的朋友可以参考下
    2023-05-05
  • python中虚拟环境创建的主流方式详细操作指南

    python中虚拟环境创建的主流方式详细操作指南

    这篇文章主要为大家详细介绍了python中虚拟环境创建的主流方式详细操作,并结合适用场景和核心特性进行对比,有需要的小伙伴可以了解下
    2025-07-07

最新评论