JsonPath是一种简单的方法来提取给定JSON文档的部分内容。 JsonPath有许多编程语言,如Javascript,Python和PHP,Java。
JsonPath提供的json解析非常强大,它提供了类似正则表达式的语法,基本上可以满足所有你想要获得的json内容。
maven中添加jar包
JsonPath可在Central Maven存储库中找到。 Maven用户将其添加到您的POM。
com.jayway.jsonpath json-path 2.2.0
操作符
操作 | 说明 |
---|---|
$ | 表示根元素 |
@ | 当前元素 |
. or [] | 子元素 |
n/a | 父元素 |
* | 通配符,表示所有的元素 |
. . | 选择所有符合条件的节点 |
[] | 迭代器标示,如数组下标 |
[,] | 连接操作符在XPath 结果合并其它结点集合。JSONP允许name或者数组索引。 |
[start?step] | 数组切片操作 |
?() | 过滤表达式 |
() | 支持表达式计算 |
函数
函数可以在路径的尾部调用,函数的输出是路径表达式的输出,该函数的输出是由函数本身所决定的。
函数 | 描述 | 输出 |
---|---|---|
min() | 提供数字数组的最小值 | Double |
max() | 提供数字数组的最大值 | Double |
avg() | 提供数字数组的平均值 | Double |
stddev() | 提供数字数组的标准偏差值 | Double |
length() | 提供数组的长度 | Integer |
过滤器运算符
过滤器是用于筛选数组的逻辑表达式。一个典型的过滤器将是[?(@.age > 18)],其中@表示正在处理的当前项目。 可以使用逻辑运算符&&和||创建更复杂的过滤器。 字符串文字必须用单引号或双引号括起来([?(@.color == ‘blue')] 或者 [?(@.color == “blue”)]).
操作符 | 描述 |
---|---|
== | left等于right(注意1不等于'1') |
!= | 不等于 |
< | 小于 |
<= | 小于等于 |
> | 大于 |
>= | 大于等于 |
=~ | 匹配正则表达式[?(@.name =~ /foo.*?/i)] |
in | 左边存在于右边 [?(@.size in [‘S', ‘M'])] |
nin | 左边不存在于右边 |
size | (数组或字符串)长度 |
empty | (数组或字符串)为空 |
Java操作示例
json格式的数据:
{ "text": "张三", "expensive": 6, "body": { "rvNoNum": 23, "rvNoRecords": [{ "score": 4, "rvAddress": "2", "consignments": null }, { "score": 8, "rvAddress": "3", "consignments": null }] } }
测试代码:
private static void jsonPathTest() { JSONObject responseJson= jsonTest();//调用自定义的jsonTest()方法获得json对象,生成上面的json //输出text的值 String text = JsonPath.read(responseJson,"$.text"); //输出rvNoNum的值 int rvNoNum = JsonPath.read(responseString,"$.body.rvNoNum"); //输出rvNoRecords数组的第2个值 List<Object> rvNoRecords = JsonPath.read(responseString,"$..rvNoRecords[1]"); //输出rvNoRecords数组的第1和第2个值 List<Object> rvNoRecords1 = JsonPath.read(responseString,"$..rvNoRecords[0,1]"); //输出rvNoRecords数组中score<=expensive的所有值 List<Object> rvNoRecords2 = JsonPath.read(responseString,"$..rvNoRecords[?(@.score < $['expensive'])]"); //输出rvNoRecords[0]的rvAddress值 String rvAddress1 = JsonPath.read(responseJson, "$.body.rvNoRecords[0].rvAddress"); //输出全部rvAddress的值,使用Iterator迭代 List<String> rvAddress = JsonPath.read(responseJson,"$.body.rvNoRecords[*].rvAddress"); //输出rvNoRecords[*]中rvAddress== '2'的rvNoRecords List<Object> rvAddress2 = JsonPath.read(responseJson,"$.body.rvNoRecords[?(@.rvAddress == 2)]"); //输出rvNoRecords[*]中score>5 的rvNoRecords List<Object> score = JsonPath.read(responseJson,"$.body.rvNoRecords[?(@.score>5)]"); //输出rvNoRecords[*]中含有consignments元素的rvNoRecords List<Double> consignments = JsonPath.read(responseString,"$.body.rvNoRecords[?(@.consignments)]"); //输出该json中所有rvAddress的值 List<Object> rvNoNum2 = JsonPath.read(responseString,"$..rvAddress"); //输出rvNoRecords数组的长度 List<Object> length = JsonPath.read(responseString,"$..rvNoRecords.length()"); //可以提前编辑一个路径,并多次使用它 JsonPath path = JsonPath.compile("$.body.rvNoRecords[*]"); List<Object> rvNoRecords3 = path.read(responseString); }
到此这篇关于使用 JSONPath 解析 JSON 完整内容详解的文章就介绍到这了,更多相关使用 JSONPath 解析 JSON 完整内容详解内容请搜索自学编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持自学编程网!
- 本文固定链接: https://zxbcw.cn/post/183279/
- 转载请注明:必须在正文中标注并保留原文链接
- QQ群: PHP高手阵营官方总群(344148542)
- QQ群: Yii2.0开发(304864863)