JsonPath详细使用教程,你了解多少?
2023-09-18 21:42:13 软件 305观看
摘要Json Path介绍看它的名字你就能知道,这Json Path和JSON文档有关系,正如XPath之于XML文档一样,JsonPath为Json文档提供了解析能力,通过使用JsonPath,你可以方便的查找节点、获取想要的数据,JsonPath是Json版的XPath。JsonPat

JiB28资讯网——每日最新资讯28at.com

Json Path介绍

看它的名字你就能知道,这Json Path和JSON文档有关系,正如XPath之于XML文档一样,JsonPath为Json文档提供了解析能力,通过使用JsonPath,你可以方便的查找节点、获取想要的数据,JsonPath是Json版的XPath。JiB28资讯网——每日最新资讯28at.com

JsonPath语法

  • 表示文档的根元素
  • 表示文档的当前元素
  • .node_name  ['node_name'] 匹配下级节点
  • [index] 检索数组中的元素
  • [start:end:step] 支持数组切片语法
  • 作为通配符,匹配所有成员
  • .. 子递归通配符,匹配成员的所有子元素
  • (<expr>) 使用表达式
  • ?(<boolean expr>)进行数据筛选

XPath与JsonPath比较

XPathJiB28资讯网——每日最新资讯28at.com

JsonPathJiB28资讯网——每日最新资讯28at.com

说明JiB28资讯网——每日最新资讯28at.com

/JiB28资讯网——每日最新资讯28at.com

$JiB28资讯网——每日最新资讯28at.com

文档根元素JiB28资讯网——每日最新资讯28at.com

.JiB28资讯网——每日最新资讯28at.com

@JiB28资讯网——每日最新资讯28at.com

当前元素JiB28资讯网——每日最新资讯28at.com

/JiB28资讯网——每日最新资讯28at.com

.或[]JiB28资讯网——每日最新资讯28at.com

匹配下级元素JiB28资讯网——每日最新资讯28at.com

..JiB28资讯网——每日最新资讯28at.com

N/AJiB28资讯网——每日最新资讯28at.com

匹配上级元素,JsonPath不支持此操作符JiB28资讯网——每日最新资讯28at.com

//JiB28资讯网——每日最新资讯28at.com

..JiB28资讯网——每日最新资讯28at.com

递归匹配所有子元素JiB28资讯网——每日最新资讯28at.com

*JiB28资讯网——每日最新资讯28at.com

*JiB28资讯网——每日最新资讯28at.com

通配符,匹配下级元素JiB28资讯网——每日最新资讯28at.com

@JiB28资讯网——每日最新资讯28at.com

N/AJiB28资讯网——每日最新资讯28at.com

匹配属性,JsonPath不支持此操作符JiB28资讯网——每日最新资讯28at.com

[]JiB28资讯网——每日最新资讯28at.com

[]JiB28资讯网——每日最新资讯28at.com

下标运算符,根据索引获取元素,XPath索引从1开始,JsonPath索引从0开始JiB28资讯网——每日最新资讯28at.com

`JiB28资讯网——每日最新资讯28at.com

`JiB28资讯网——每日最新资讯28at.com

[,]JiB28资讯网——每日最新资讯28at.com

N/AJiB28资讯网——每日最新资讯28at.com

[start:end:step]JiB28资讯网——每日最新资讯28at.com

数据切片操作,XPath不支持JiB28资讯网——每日最新资讯28at.com

[]JiB28资讯网——每日最新资讯28at.com

?()JiB28资讯网——每日最新资讯28at.com

过滤表达式JiB28资讯网——每日最新资讯28at.com

N/AJiB28资讯网——每日最新资讯28at.com

()JiB28资讯网——每日最新资讯28at.com

脚本表达式,使用底层脚本引擎,XPath不支持JiB28资讯网——每日最新资讯28at.com

()JiB28资讯网——每日最新资讯28at.com

N/AJiB28资讯网——每日最新资讯28at.com

分组,JsonPath不支持JiB28资讯网——每日最新资讯28at.com

示例

下面是相应的JsonPath的示例,代码来源于https://goessner/articles/JsonPath/,JSON文档如下:JiB28资讯网——每日最新资讯28at.com

{	"store": {		"book": [{				"category": "reference",				"author": "Nigel Rees",				"title": "Sayings of the Century",				"price": 8.95			}, {				"category": "fiction",				"author": "Evelyn Waugh",				"title": "Sword of Honour",				"price": 12.99			}, {				"category": "fiction",				"author": "Herman Melville",				"title": "Moby Dick",				"isbn": "0-553-21311-3",				"price": 8.99			}, {				"category": "fiction",				"author": "J. R. R. Tolkien",				"title": "The Lord of the Rings",				"isbn": "0-395-19395-8",				"price": 22.99			}		],		"bicycle": {			"color": "red",			"price": 19.95		}	}}

解析情况如下:JiB28资讯网——每日最新资讯28at.com

XPathJiB28资讯网——每日最新资讯28at.com

JsonPathJiB28资讯网——每日最新资讯28at.com

ResultJiB28资讯网——每日最新资讯28at.com

/store/book/authorJiB28资讯网——每日最新资讯28at.com

$.store.book[*].authorJiB28资讯网——每日最新资讯28at.com

所有book的author节点JiB28资讯网——每日最新资讯28at.com

//authorJiB28资讯网——每日最新资讯28at.com

$..authorJiB28资讯网——每日最新资讯28at.com

所有author节点JiB28资讯网——每日最新资讯28at.com

/store/*JiB28资讯网——每日最新资讯28at.com

$.store.*JiB28资讯网——每日最新资讯28at.com

store下的所有节点,book数组和bicycle节点JiB28资讯网——每日最新资讯28at.com

/store//priceJiB28资讯网——每日最新资讯28at.com

$.store..priceJiB28资讯网——每日最新资讯28at.com

store下的所有price节点JiB28资讯网——每日最新资讯28at.com

//book[3]JiB28资讯网——每日最新资讯28at.com

$..book[2]JiB28资讯网——每日最新资讯28at.com

匹配第3个book节点JiB28资讯网——每日最新资讯28at.com

//book[last()]JiB28资讯网——每日最新资讯28at.com

$..book[(@.length-1)],或 $..book[-1:]JiB28资讯网——每日最新资讯28at.com

匹配倒数第1个book节点JiB28资讯网——每日最新资讯28at.com

//book[position()<3]JiB28资讯网——每日最新资讯28at.com

$..book[0,1],或 $..book[:2]JiB28资讯网——每日最新资讯28at.com

匹配前两个book节点JiB28资讯网——每日最新资讯28at.com

//book[isbn]JiB28资讯网——每日最新资讯28at.com

$..book[?(@.isbn)]JiB28资讯网——每日最新资讯28at.com

过滤含isbn字段的节点JiB28资讯网——每日最新资讯28at.com

//book[price<10]JiB28资讯网——每日最新资讯28at.com

$..book[?(@.price<10)]JiB28资讯网——每日最新资讯28at.com

过滤price<10的节点JiB28资讯网——每日最新资讯28at.com

//*JiB28资讯网——每日最新资讯28at.com

$..*JiB28资讯网——每日最新资讯28at.com

递归匹配所有子节点JiB28资讯网——每日最新资讯28at.com

可以在http://jsonpath.com/站点进行验证JsonPath的执行效果。JiB28资讯网——每日最新资讯28at.com

java中使用

pom中引用JiB28资讯网——每日最新资讯28at.com

<dependency>            <groupId>com.jayway.jsonpath</groupId>            <artifactId>json-path</artifactId>            <version>2.4.0</version>        </dependency>

通常是直接使用静态方法API进行调用,例如:JiB28资讯网——每日最新资讯28at.com

String json = "...";List<String> authors = JsonPath.read(json, "$.store.book[*].author");

但以上方式仅仅适用于解析一次json的情况,如果需要对同一个json解析多次,不建议使用,因为每次read都会重新解析一次json,针对此种情况,建议使用ReadContext、WriteContext,例如:JiB28资讯网——每日最新资讯28at.com

String json = "..."; ReadContext ctx = JsonPath.parse(json); List<String> authorsOfBooksWithISBN = ctx.read("$.store.book[?(@.isbn)].author"); List<Map<String, Object>> expensiveBooks = JsonPath                            .using(configuration)                            .parse(json)                            .read("$.store.book[?(@.price > 10)]", List.class);

本文链接:http://www.28at.com/showinfo-26-10484-0.htmlJsonPath详细使用教程,你了解多少?

声明:本网页内容旨在传播知识,不代表本站观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。

显示全文

上一篇:零拷贝并非万能解决方案:重新定义数据传输的效率极限

下一篇:Springboot — 用更优雅的方式发HTTP请求(RestTemplate详解)

最新热点