zoukankan      html  css  js  c++  java
  • JsonPath基本用法

    JsonPath基本用法

    本文主要介绍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 说明
    / $ 文档根元素
    . @ 当前元素
    / .[] 匹配下级元素
    .. N/A 匹配上级元素,JsonPath不支持此操作符
    // .. 递归匹配所有子元素
    * * 通配符,匹配下级元素
    @ N/A 匹配属性,JsonPath不支持此操作符
    [] [] 下标运算符,根据索引获取元素,XPath索引从1开始,JsonPath索引从0开始
    | [,] 连接操作符,将多个结果拼接成数组返回,可以使用索引或别名
    N/A [start:end:step] 数据切片操作,XPath不支持
    [] ?() 过滤表达式
    N/A () 脚本表达式,使用底层脚本引擎,XPath不支持
    () N/A 分组,JsonPath不支持

    注意:

    • JsonPath的索引从0开始计数
    • JsonPath中字符串使用单引号表示,例如:$.store.book[?(@.category=='reference')]中的'reference'

    JsonPath示例

    下面是相应的JsonPath的示例,代码来源于https://goessner.net/articles/JsonPath/,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
    /store/book/author $.store.book[*].author 所有book的author节点
    //author $..author 所有author节点
    /store/* $.store.* store下的所有节点,book数组和bicycle节点
    /store//price $.store..price store下的所有price节点
    //book[3] $..book[2] 匹配第3个book节点
    //book[last()] $..book[(@.length-1)],或 $..book[-1:] 匹配倒数第1个book节点
    //book[position()<3] $..book[0,1],或 $..book[:2] 匹配前两个book节点
    //book[isbn] $..book[?(@.isbn)] 过滤含isbn字段的节点
    //book[price<10] $..book[?(@.price<10)] 过滤price<10的节点
    //* $..* 递归匹配所有子节点

    你可以在http://jsonpath.com/站点进行验证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')]");
    

    参考文档:

  • 相关阅读:
    Java堆和优先队列
    JAVA取数两个数组交集,考虑重复和不重复元素
    Java策略模式
    Java设计模式迭代器
    Java 模板模式
    java图片缩放与裁剪
    Java桥接模式
    Java集合实现
    Java Mybatis实现主从同步
    Java组合模式
  • 原文地址:https://www.cnblogs.com/youring2/p/10942728.html
Copyright © 2011-2022 走看看