Jsonpath 使用说明

Jsonpath 使用说明

介绍

JSONPath 是一种用于从 JSON 数据结构中提取特定元素的查询语言,类似于 XPath 用

于 XML。它提供了强大的查询功能,允许用户通过简单的表达式获取 JSON 文档中的特定

数据。

2. JSONPath 基础语法

JSONPath 的查询表达式以 $ 开始,表示根元素,支持多种操作符,如 .、[]、* 和过

滤器 [?()] 等,用来进行数据的提取和过滤。

java 复制代码
{ 
 "store": {
 "book": [
 {"category": "fiction", "price": 8.99, "title": "Book 1"},
 {"category": "science", "price": 12.99, "title": "Book 2"}
 ],
 "bicycle": {"color": "red", "price": 19.95}
 } 
} 

2.1.根节点

$ 表示根元素。

2.2.成员访问

1、.:直接访问子元素,例如 $.store.book。

2、[]:使用键或索引进行访问,例如 $['store']['book']。

2.3.通配符

""用于匹配所有的子元素。例如 $.store.book[] 匹配所有的书籍元素。

2.4.数组操作

1、[index]:选择指定下标的数组元素,例如 $.store.book[0] 选择第一个书籍。

2、[start:end]:选择范围内的数组元素,例如 $.store.book[0:2] 选择前两个书籍。

2.5.过滤器

?()\] 用于过滤元素。表达式 @ 代表当前元素。例如,$.store.book\[?(@.price \> 10)\] 返 回价格大于 10 的书籍。 #### 2.6.递归搜索 ... 用于递归搜索整个 JSON 结构。例如,$.store...price 会查找所有名为 price 的元素。 ### 3. 使用示例 #### 3.1.获取根节点为对象 ##### 3.1.1. 对象节点 $.store.bicycle.color ##### 3.1.2. 数组节点 $.store.book\[\*\].title ##### 3.1.3. 数组中数组节点 $.store.book\[*\].pages\[* \].content ![在这里插入图片描述](https://i-blog.csdnimg.cn/direct/69b147dabcd54e2c97a3daba6312ae6f.png) ##### 3.1.4. 递归搜索 $.store...price ![在这里插入图片描述](https://i-blog.csdnimg.cn/direct/51d096bc00c047439c018a0a3488c5a4.png) ##### 3.1.5. 不存在节点 $.store.author ![在这里插入图片描述](https://i-blog.csdnimg.cn/direct/d4855a9f725141afbe982ce02ce1ea86.png) #### 3.2.获取根节点为数组 ##### 3.2.1. 对象数据 $. \[\*\].FileType ![在这里插入图片描述](https://i-blog.csdnimg.cn/direct/12e52c665b9741fb8f785f83660cc0fa.png)

相关推荐
sali-tec1 小时前
C# 基于halcon的视觉工作流-章48-短路断路
开发语言·图像处理·人工智能·算法·计算机视觉
渣哥1 小时前
从代理到切面:Spring AOP 的本质与应用场景解析
javascript·后端·面试
UIUV2 小时前
JavaScript代理模式实战解析:从对象字面量到情感传递的优雅设计
javascript
摸着石头过河的石头2 小时前
JavaScript 防抖与节流:提升应用性能的两大利器
前端·javascript
_大学牲2 小时前
FuncAvatar: 你的头像氛围感神器 🤥🤥🤥
前端·javascript·程序员
无敌最俊朗@2 小时前
解决 QML 中使用 Qt Charts 崩溃的三个关键步骤
开发语言·qt
渣哥2 小时前
面试必问:Spring Bean 的作用域类型有多少种?
javascript·后端·面试
会飞的小新2 小时前
C 标准库之 <errno.h> 详解与深度解析
c语言·开发语言
氦客2 小时前
Android Compose 状态的概念
android·compose·重组·状态·组合·mutablestate·mutablestateof
533_2 小时前
[element-ui] el-tree 组件鼠标双击事件
前端·javascript·vue.js