JsonPath基本使用
Posted dotNET跨平台
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JsonPath基本使用相关的知识,希望对你有一定的参考价值。
概述
在.Net开发中,一般操作Json都是使用Newtonsoft.Json包,下面我们来使用该包以类似xpath的方式JsonPath操作Json。
介绍
JsonPath是xpath在json中的应用,是参照xpath表达式来解析xml文档的方式,用一个抽象的名字$来表示最外层的对象。常见的写法
$.store.book[0].title
$['store']['book'][0]['title']
在线测试网站:http://jsonpath.com/
JSONPath 允许使用通配符 * 表示所以的子元素名和数组索引。还允许使用 '..' (从E4X参照过来的和数组切分语法),示例
$.store.book[(@.length-1)].title
-- 使用'@'符号表示当前的对象,?(<判断表达式>) 使用逻辑表达式来过滤。
$.store.book[?(@.price < 10)].title
操作对比
XPath | JSONPath | Description |
---|---|---|
/ | $ | 表示根元素 |
. | @ | 当前元素 |
/ | . or [] | 子元素 |
.. | n/a | 父元素 |
// | .. | 递归下降,JSONPath是从E4X借鉴的。 |
* | * | 通配符,表示所有的元素 |
@ | n/a | 属性访问字符 |
[] | [] | 子元素操作符 |
| | [,] | 连接操作符在XPath 结果合并其它结点集合。JSONP允许name或者数组索引。 |
n/a | [start:end:step] | 数组分割操作从ES4借鉴。 |
[] | ?() | 应用过滤表示式 |
n/a | () | 脚本表达式,使用在脚本引擎下面。 |
() | n/a | Xpath分组 |
示例
下面是一个简单的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
操作示例
var str = File.ReadAllText("aa.txt");
JObject jobj = JObject.Parse(str);
var bb = jobj.SelectToken("$.data.emrMenuDisplayModels[2]['identify']");
//书点所有书的作者
var autherList = jobj.SelectTokens("$.store.book[*].author");
//所有的作者
var autherList2 = jobj.SelectTokens("$...author");
//store的所有元素。所有的bookst和bicycle
var store1 = jobj.SelectTokens("$.store.*");
//store里面所有东西的price
var store2 = jobj.SelectTokens("$.store..['price']");
var store3 = jobj.SelectTokens("$.store..price");
//第三个书
var book1 = jobj.SelectTokens("$.store.book[2]");
var book2 = jobj.SelectTokens("$..book[2]");
// 最后一本书
var book3 = jobj.SelectTokens("$..book[-1:]");
//var book3 = jobj.SelectTokens("$..book[(@.len-1)]");//不支持@.length
//var book4 = jobj.SelectTokens("$.store.book[(@.length-1)]");
//前面的两本书
var laing = jobj.SelectTokens("$..book[0,1]");
//过滤出所有的包含isbn的书
var contain = jobj.SelectTokens("$..book[?(@.isbn)]");
//过滤出价格低于10的书。
var price = jobj.SelectTokens("$..book[?(@.price<10)]");
//所有元素
var all = jobj.SelectTokens("$..*");
资料
参考资料:https://blog.csdn.net/myself8202/article/details/80724968
以上是关于JsonPath基本使用的主要内容,如果未能解决你的问题,请参考以下文章