Python JSON 详解教程

boyanx1周前技术教程4

JSONJavaScript Object Notation)是一种轻量级的数据交换格式(lightweight data interchange format)

常用于 Web 应用、配置文件(configuration files,)和数据通信

本文将介绍如何使用 Python 内置的 json 模块,实现(Implement)字典与 JSON 字符串的转换、文件的读写,以及在实际案例中处理数据(in practical cases)


1. 什么是 JSON?

JSON 是一种基于文本(text-based)的格式,用来表示结构化数据(represent structured data),易于人阅读和编写,同时也易于机器解析和生成。


2. Python 中的 json 模块

Python 提供了内置的 json 模块

无需额外安装(without additional installation)——
即可完成数据的序列化(serialization)(转换成 JSON 字符串)与反序列化(deserialization)(解析 JSON 字符串)。

2.1 字典与 JSON 字符串转换 (Dictionary <-> JSON String)

示例:

import json
data = {
    "name": "梓豪",  
    "age": 25,
    "city": "青岛"    
}
# 将字典转换为 JSON 字符串 (Serialize)
json_str = json.dumps(data, indent=4, ensure_ascii=False)
print("JSON 字符串:")
print(json_str)
# 将 JSON 字符串转换回字典 (Deserialize)
data_back = json.loads(json_str)
print("还原的字典:", data_back)

说明:

  • json.dumps() 将 Python 对象转换为 JSON 字符串
  • 参数 indent=4 用于格式化输出,ensure_ascii=False 保证中文不被转义(been not escaped)

3. 文件操作:读写 JSON 文件

通过文件读写,可以将 JSON 数据存储到磁盘或从磁盘加载数据。

3.1 写入 JSON 到文件

import json

orders = {
    "订单": [
        {"订单号": 101, "顾客": "梓涵", "total": 120},
        {"订单号": 102, "顾客": "梓萱", "total": 80}
    ]
}

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

说明:

  • 使用 json.dump() 直接将数据写入文件,with 语句确保文件自动关闭

3.2 从文件读取 JSON

import json

with open("orders.json", "r", encoding="utf-8") as f:
    orders_data = json.load(f)
    print("加载的订单数据:")
    print(orders_data)

说明:

  • json.load() 从文件中读取并解析 JSON 数据,生成相应的 Python 对象。

4. 实际案例:处理生活订单数据

假设你经营一家小店,存储了订单信息的 JSON 数据,我们可以用以下代码遍历订单并给出消费建议。

import json

orders_json = '''
{
    "orders": [
        {"order_id": 1, "customer": "诗涵", "total": 45},
        {"order_id": 2, "customer": "雨桐", "total": 75},
        {"order_id": 3, "customer": "宇轩", "total": 30}
    ]
}
'''

orders_data = json.loads(orders_json) #转换为 Python 字典

for order in orders_data["orders"]:
    if order["total"] > 50:
        advice = "消费较高,送积分奖励!"  
    else:
        advice = "消费一般,欢迎下次光临!"  
    print(f"订单 {order['order_id']} 的客户 {order['customer']}:{order['total']} 元 -> {advice}")



5. 小贴士与注意事项 (Tips & Caveats)

  • ensure_ascii=False:保证输出中文时不会转义为 Unicode。

  • indent 参数:使生成的 JSON 更加美观易读(readable)

  • 区分 json.dumps 与 json.dump:前者返回字符串,后者直接写入文件。

  • 异常处理:处理文件读写时建议加上异常捕获,防止文件不存在或格式错误。
    (use try-except blocks for file operations to handle errors gracefully.)
标签: js格式化json

相关文章

详细介绍一下Python如何对JSON格式数据进行处理?

在Python中对于JSON数据的处理是在日常开发中的常见需求之一。通常情况下,对JSON数据的处理主要涉及到如下的的几个步骤对于JSON数据的解析操作对于JSON数据的处理操作对于JSON数据的格式...

从0到精通,System.Text.Json进阶技巧曝光,性能提升3倍!

一、引言在现代软件开发中,JSON(JavaScript Object Notation)作为一种轻量级的数据交换格式,被广泛应用于前后端交互、配置文件管理以及分布式系统间的数据传输。System....

VS Code常用的插件分享

VS Code前端开发工具之必备插件,Visual Studio Code是由微软开发免费、开源、跨平台的一款IDE,支持多种编程语言开发,具有强大的插件扩展能力,这篇文章我们就来看看VS Code在...

「Postman」测试(Tests)脚本编写和断言详解

测试确认您的 API 按预期工作,服务之间的集成运行可靠,并且新开发没有破坏任何现有功能。您可以使用 JavaScript 为 Postman API 请求编写测试脚本。当您的 API 项目出现问题时...

越晚搞懂 MySQL JSON 数据类型,你就越吃亏

作者介绍陈臣,甲骨文MySQL首席解决方案工程师,公众号《MySQL实战》作者,有大规模的MySQL,Redis,MongoDB,ES的管理和维护经验,擅长MySQL数据库的性能优化及日常操作的原理剖...

针对MySQL特有函数的梧桐替代解决方法

MySQL 8.0 特有函数清单包含了一些重要的JSON函数、正则表达式函数和地理空间函数,我们针对这些内容,梳理了基于梧桐6.0版本的替代解决方法。以方便用户在平时的国产化项目及其它工作中更加方便的...

发表评论    

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。