python json 库 jsonpath_ng

jsonpath_ng 是 Python 中一款解析和操作 JSON 数据的工具,它可以通过 JSONPath 语法来对 JSON 数据进行定位和提取,其用法类似于 XPath 语法对 XML 数据进行定位。

安装

在使用 jsonpath_ng 之前,需要先安装该库。可以通过 pip 命令进行安装,如下所示:

pip install jsonpath_ng

使用

取 dict 中的数据

假设有如下 JSON 数据:

bash 复制代码
{
    "code": 1,
    "result": {
        "msg": "success"
    }
}

获取 msg 字段的信息。可以通过如下代码来实现:

python 复制代码
from jsonpath_ng import parse

data = {"code": 1, "result": {"msg": "success"}}

msg_path = parse("$.result.msg")

# 获取 msg 的信息
msg_path.find(data)[0].value  # success

在上面的代码中,我们首先导入了 jsonpath_ng 库,并将 JSON 数据转换为 Python 中的 dict 类型。接着,我们使用 parse 函数来解析 JSONPath 表达式 $.result.msg,并将其赋值给变量 msg_path。最后,我们通过调用 find 方法并传入 JSON 数据,来获取 msg 的值。

取 list 中的数据

假设有如下 JSON 数据:

bash 复制代码
{
    "code": 1,
    "result": [
        {"id": 1},
        {"id": 2}
    ]
}

获取 id 字段的信息。可以通过如下代码来实现:

python 复制代码
from jsonpath_ng import parse

data = {"code": 1, "result": [{"id": 1}, {"id": 2}]}

list_path = parse("$.result[*].id")

# 获取 list 中 id 的信息
list_path.find(data)[0].value  # 1
list_path.find(data)[1].value  # 2

在上面的代码中,同样使用 parse 函数来解析 JSONPath 表达式 $.result[*].id,并将其赋值给变量 list_path。通过调用 find 方法来获取 id 的值。需要注意的是,由于 result 字段是一个列表,需要使用 [*] 来表示列表中的所有元素。

原文链接:https://blog.csdn.net/weixin_44649870/article/details/117778159

相关推荐
JQLvopkk9 小时前
C# 轻量级工业温湿度监控系统(含数据库与源码)
开发语言·数据库·c#
玄同7659 小时前
从 0 到 1:用 Python 开发 MCP 工具,让 AI 智能体拥有 “超能力”
开发语言·人工智能·python·agent·ai编程·mcp·trae
czy87874759 小时前
深入了解 C++ 中的 `std::bind` 函数
开发语言·c++
消失的旧时光-19439 小时前
从 Kotlin 到 Dart:为什么 sealed 是处理「多种返回结果」的最佳方式?
android·开发语言·flutter·架构·kotlin·sealed
yq1982043011569 小时前
静思书屋:基于Java Web技术栈构建高性能图书信息平台实践
java·开发语言·前端
一个public的class9 小时前
你在浏览器输入一个网址,到底发生了什么?
java·开发语言·javascript
Jinkxs9 小时前
Gradle - 与Groovy/Kotlin DSL对比 构建脚本语言选择指南
android·开发语言·kotlin
&有梦想的咸鱼&9 小时前
Kotlin委托机制的底层实现深度解析(74)
android·开发语言·kotlin
小瑞瑞acd9 小时前
【小瑞瑞精讲】卷积神经网络(CNN):从入门到精通,计算机如何“看”懂世界?
人工智能·python·深度学习·神经网络·机器学习
火车叼位9 小时前
也许你不需要创建.venv, 此规范使python脚本自备依赖
python