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)

相关推荐
小张快跑。5 分钟前
【Vue3】(三)vue3中的pinia状态管理、组件通信
前端·javascript·vue.js
我想说一句5 分钟前
当 map 遇上 parseInt:JS 中一场参数引发的“血案”
前端·javascript·面试
三气归来7 分钟前
2. 内置模块之http模块
javascript·后端
FogLetter8 分钟前
🧙‍♂️ 魔法笔记:JavaScript 词法作用域与闭包的神秘世界
javascript·后端
harry235day12 分钟前
Compose 带动画的待办清单列表页
android·android jetpack
vocal13 分钟前
我的安卓第一课:四大组件之一Activity及其组件RecyclerView
android
天天码行空14 分钟前
Bootstrap Table企业级web数据表格集成框架
前端·javascript·开源
CodeWithMe17 分钟前
【C/C++】EBO空基类优化介绍
开发语言·c++
Hilaku23 分钟前
用好了 defineProps 才叫会用 Vue3,90% 的写法都错了
前端·javascript·vue.js
英宋25 分钟前
ckeditor5的研究 (2):对 CKEditor5 进行设计,并封装成一个可用的 vue 组件
前端·javascript