网站首页 > 技术文章 正文
在现代Web开发中,JSON(JavaScript Object Notation)已成为数据交换的标准格式。它以其简洁和易于阅读的结构受到广泛欢迎。然而,随着数据结构的复杂化,如何高效地从JSON中提取所需信息成为开发者面临的一个挑战。JSONPath应运而生,作为一种强大的查询工具,帮助开发者轻松地从JSON数据中提取信息。
1.什么是JSONPath?
JSONPath是一种用于JSON数据的查询语言,类似于XPath用于XML。它允许开发者使用一种类路径语法来导航和提取JSON文档中的数据。JSONPath的语法简单直观,使得即使是复杂的查询也能轻松实现。
2.JSONPath的基本语法
JSONPath的语法由一系列路径表达式组成,以下是一些常用的语法元素:
- $:表示根元素。
- .:用于访问子元素。
- []:用于访问数组元素或过滤。
- *:通配符,表示所有元素。
- ..:递归下降,搜索所有子元素。
- ?():用于过滤表达式。
3.JSONPath的优势
- 简洁性:JSONPath的语法简洁明了,易于学习和使用。
- 灵活性:支持复杂的查询和过滤操作,能够处理各种JSON结构。
- 广泛支持:许多编程语言和工具都支持JSONPath,使其成为跨平台的解决方案。
4.代码工程
4.1. 添加依赖
如果你使用Maven构建项目,可以在pom.xml中添加以下依赖:
<dependency>
<groupId>com.jayway.jsonpath</groupId>
<artifactId>json-path</artifactId>
<version>2.8.0</version>
</dependency>
4.2. 使用JsonPath解析JSON
假设我们有以下JSON数据:
{
"store": {
"book": [
{ "category": "fiction", "title": "The Great Gatsby", "price": 10.99 },
{ "category": "non-fiction", "title": "Sapiens", "price": 15.99 }
],
"bicycle": {
"color": "red",
"price": 19.95
}
}
}
我们可以使用JsonPath来提取数据:
package com.et;
import com.jayway.jsonpath.JsonPath;
import java.util.List;
public class JsonPathExample {
public static void main(String[] args) {
String jsonString = "{ \"store\": { \"book\": [ { \"category\": \"fiction\", \"title\": \"The Great Gatsby\", \"price\": 10.99 }, { \"category\": \"non-fiction\", \"title\": \"Sapiens\", \"price\": 15.99 } ], \"bicycle\": { \"color\": \"red\", \"price\": 19.95 } } }";
// Extract all book titles
List<String> titles = JsonPath.read(jsonString, "$.store.book[*].title");
System.out.println("Book Titles: " + titles);
// Extract books with a price less than 15
List<Object> cheapBooks = JsonPath.read(jsonString, "$.store.book[?(@.price < 15)]");
System.out.println("Cheap Books: " + cheapBooks);
// Extract all prices in the store
List<Double> prices = JsonPath.read(jsonString, "$.store..price");
System.out.println("Prices: " + prices);
}
}
4.3. 解析结果
- 提取所有书籍的标题:使用路径$.store.book[*].title,返回所有书籍的标题。
- 提取价格低于15的书籍:使用路径$.store.book[?(@.price < 15)],返回价格低于15的书籍对象。
- 提取商店中所有物品的价格:使用路径$.store..price,返回所有价格。
以上只是一些关键代码,所有代码请参见下面代码仓库
代码仓库
- https://github.com/Harries/springboot-demo(jsonpath)
5.测试
- 提取所有书籍的标题:
- JSONPath:$.store.book[*].title
- 结果:["The Great Gatsby", "Sapiens"]
- 提取价格低于15的书籍:
- JSONPath:$.store.book[?(@.price < 15)]
- 结果:[{ "category": "fiction", "title": "The Great Gatsby", "price": 10.99 }]
- 提取商店中所有物品的价格:
- JSONPath:$.store..price
- 结果:[10.99, 15.99, 19.95]
6.引用
- https://github.com/json-path/JsonPath
猜你喜欢
- 2025-01-09 精通Spring Boot 3 : 13. Spring Cloud 与 Spring Boot (4)
- 2025-01-09 Spring Boot集成Redis Search快速入门Demo
- 2025-01-09 Spring Boot 3.x嵌入MongoDB 进行测试
- 2025-01-09 java安全之fastjson链分析
- 2025-01-09 MyBatis初级实战之五:一对一关联查询
- 2025-01-09 精通Spring Boot 3 : 8. Spring Boot 测试 (2)
- 2025-01-09 DevSecOps 管道: 使用Jenkins实现安全的多语言应用程序
- 2025-01-09 Liquibase+Spring+Maven: 管理数据库轻松搞定
- 2025-01-09 比较一下JSON与XML两种数据格式?
- 2025-01-09 Java批量导入时,如何去除重复数据并返回结果?
- 05-15总结雅虎前端性能优化技巧(16条)
- 05-15日常生活中吃雪莲果有养生功效也有危害
- 05-15API 安全之认证鉴权
- 05-15Chaosblade: 阿里一个超级牛逼的混沌实验实施工具
- 05-15膨来仙岛丨搞电竞的都是什么成分?
- 05-15大事全知晓!2022年新闻日历来了!
- 05-15你是有多久没看过麦田圈了?一篇文章全面回顾2015麦田圈季
- 05-15魔兽世界9.1 刻希亚寻找宝箱、稀有WA(转自nga)
- 最近发表
- 标签列表
-
- cmd/c (64)
- c++中::是什么意思 (83)
- 标签用于 (65)
- 主键只能有一个吗 (66)
- c#console.writeline不显示 (75)
- pythoncase语句 (81)
- es6includes (73)
- sqlset (64)
- windowsscripthost (67)
- apt-getinstall-y (86)
- node_modules怎么生成 (76)
- chromepost (65)
- c++int转char (75)
- localstorage.removeitem (74)
- vector线程安全吗 (70)
- & (66)
- java (73)
- org.redisson (64)
- js数组插入 (83)
- gormwherein (64)
- linux删除一个文件夹 (65)
- mac安装java (72)
- eacces (67)
- 查看mysql是否启动 (70)
- 无效的列索引 (74)