本文主要介绍JsonPath的基本语法,并演示如何在Newtonsoft.Json中进行使用。
JsonPath的来源
看它的名字你就能知道,这家伙和JSON文档有关系,正如XPath之于XML文档一样,JsonPath为Json文档提供了解析能力,通过使用JsonPath,你可以方便的查找节点、获取想要的数据,JsonPath是Json版的XPath。
JsonPath语法
JsonPath的语法相对简单,它采用开发语言友好的表达式形式,如果你了解类C语言,对JsonPath就不会感到不适应。
JsonPath语法要点:
-
$
表示文档的根元素 -
@
表示文档的当前元素 -
.node_name
或['node_name']
匹配下级节点 -
[index]
检索数组中的元素 -
[start:end:step]
支持数组切片语法 -
*
作为通配符,匹配所有成员 -
..
子递归通配符,匹配成员的所有子元素 -
(<expr>)
使用表达式 -
?(<boolean expr>)
进行数据筛选
下表将列举所有支持的语法,并对XPath进行比较:
XPath | JsonPath | 说明 |
|
| 文档根元素 |
|
| 当前元素 |
|
| 匹配下级元素 |
|
| 匹配上级元素,JsonPath不支持此操作符 |
|
| 递归匹配所有子元素 |
|
| 通配符,匹配下级元素 |
|
| 匹配属性,JsonPath不支持此操作符 |
|
| 下标运算符,根据索引获取元素,XPath索引从1开始,JsonPath索引从0开始 |
` | ` |
|
|
| 数据切片操作,XPath不支持 |
|
| 过滤表达式 |
|
| 脚本表达式,使用底层脚本引擎,XPath不支持 |
|
| 分组,JsonPath不支持 |
注意:
- JsonPath的索引从0开始计数
- JsonPath中字符串使用单引号表示,例如:
$.store.book[?(@.category=='reference')]
中的'reference'
JsonPath示例
下面是相应的JsonPath的示例,代码来源于JSONPath - XPath for JSON,JSON文档如下:
{
"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
}
}
}
接下来我们看一下如何对这个文档进行解析:
XPath | JsonPath | Result |
|
| 所有book的author节点 |
|
| 所有author节点 |
|
| store下的所有节点,book数组和bicycle节点 |
|
| store下的所有price节点 |
|
| 匹配第3个book节点 |
|
| 匹配倒数第1个book节点 |
|
| 匹配前两个book节点 |
|
| 过滤含isbn字段的节点 |
|
| 过滤 |
|
| 递归匹配所有子节点 |
你可以在JSONPath Online Evaluator站点进行验证JsonPath的执行效果。 |
在Newtonsoft.Json中的用法
JsonPath是语言无关的表达式语言,Newtonsoft.Json库提供了对JsonPath的支持,它提供了JObject.SelectToken()
和JObject.SelectTokens()
方法来使用JsonPath解析Json文档,代码如下:
//创建JObject对象
var jObj = JObject.Parse(jsonString);
var books = jObj.SelectToken("$.store.book[?(@.category=='reference')]");
参考文档: