1、简述
JSONPath 是一种强大的工具,用于查询和操作 JSON 数据。类似于 SQL 的语法,它为处理复杂的 JSON 数据结构提供了简单且高效的解决方案。✨
代码样例:https://gitee.com/lhdxhl/springboot-example.git
本文将介绍 JSONPath 的基本语法,并通过详细的 Java 示例展示其实际应用。🚀
2、🌟 什么是 JSONPath?
JSONPath 是一种用于 JSON 文档的路径表达式语言,类似于 XPath(用于 XML)。它允许我们:
- 提取 JSON 中的值
- 过滤和操作数据
- 遍历嵌套结构
基本语法规则:
JSONPath 表达式 | 功能说明 |
---|---|
$ | 根对象 |
. 或 [] | 访问子元素 |
* | 通配符,匹配所有元素 |
.. | 递归搜索 |
?() | 过滤表达式 |
@ | 当前元素 |
在使用 JSONPath 之前,需要添加其依赖。以下是 JSONPath 的 Maven 依赖:
<dependency><groupId>com.jayway.jsonpath</groupId><artifactId>json-path</artifactId><version>2.8.0</version>
</dependency>
3、✍️ Java 示例
在 Java 中,我们可以使用开源库 Jayway JSONPath 来实现 JSONPath 的功能。以下示例 JSON 数据:
{"store": {"book": [{ "category": "fiction", "author": "John", "price": 10.99 },{ "category": "science", "author": "Jane", "price": 12.99 },{ "category": "fiction", "author": "George", "price": 8.99 }],"bicycle": {"color": "red","price": 99.99}}
}
3.1 基本查询
从 JSON 中获取所有书籍的类别。
import com.jayway.jsonpath.JsonPath;
import java.util.List;public class JSONPathDemo {public static void main(String[] args) {String json = """{"store": {"book": [{ "category": "fiction", "author": "John", "price": 10.99 },{ "category": "science", "author": "Jane", "price": 12.99 },{ "category": "fiction", "author": "George", "price": 8.99 }]}}""";List<String> categories = JsonPath.read(json, "$.store.book[*].category");System.out.println("📚书籍类别: " + categories);}
}
输出:
📚书籍类别: [fiction, science, fiction]
3.2 过滤查询
获取价格大于 10 的书籍。
List<Map<String, Object>> expensiveBooks = JsonPath.read(json, "$.store.book[?(@.price > 10)]");
System.out.println("💰价格大于 10 的书籍: " + expensiveBooks);
输出:
💰价格大于 10 的书籍: [{category=fiction, author=John, price=10.99}, {category=science, author=Jane, price=12.99}]
3.3 递归搜索
获取所有价格字段。
List<Double> prices = JsonPath.read(json, "$.store..price");
System.out.println("💵所有价格: " + prices);
输出:
💵所有价格: [10.99, 12.99, 8.99, 99.99]
3.4 嵌套查询
获取自行车的颜色。
String color = JsonPath.read(json, "$.store.bicycle.color");
System.out.println("🚲自行车颜色: " + color);
输出:
🚲自行车颜色: red
3.5 结合 POJO 使用
将查询结果映射到 Java 对象中。
import com.fasterxml.jackson.databind.ObjectMapper;class Book {private String category;private String author;private double price;// Getters and Setters
}List<Book> books = JsonPath.parse(json).read("$.store.book[*]", new TypeRef<List<Book>>() {});
books.forEach(book -> System.out.println("📖书籍: " + book.getCategory() + " by " + book.getAuthor()));
4、🚀 高级用法
4.1 动态路径
根据用户输入动态生成 JSONPath 表达式。
String category = "fiction";
String jsonPath = String.format("$.store.book[?(@.category == '%s')]", category);
List<Map<String, Object>> result = JsonPath.read(json, jsonPath);
System.out.println("🔍查询结果: " + result);
4.2 自定义函数
通过扩展 JSONPath 的功能,实现复杂逻辑。
Configuration conf = Configuration.builder().options(Option.DEFAULT_PATH_LEAF_TO_NULL).functions(new CustomFunctions()).build();
DocumentContext context = JsonPath.using(conf).parse(json);
5、总结
JSONPath 是处理 JSON 数据的利器,其直观的语法和强大的功能使得 JSON 数据操作变得轻松自如。通过结合 Java 和第三方库,可以在各种场景下高效应用 JSONPath。
希望本文的内容对您有所帮助!🎉