jsonpath - 使用 JSONPath 解析 JSON 完整内容详解

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);
}

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值