您的位置:

JSONPath表达式详解

在处理 JSON 数据时,JSONPath 是一种非常重要的工具。它可以像 XPath 对 XML 数据操作一样,对 JSON 数据进行筛选、遍历和子集选择等操作。JSONPath常见于前端和后端的开发中,尤其是在Web API返回JSON数据或者前端调用JSON接口时,都用的非常频繁。

一、JSONPath基本语法

JSONPath 是一种路径表达式语言,基本的语法形如 $.keyname,其中 $ 符号表示根节点,而 keyname 是要取值的字段名称或数组下标。JSONPath 中最简单的表达式就是 " $ ",代表着整个 JSON 数据对象。下面我们来看看一些常用的 JSONPath 表达式:

$.store.book[*].author 
$.['store']['book'][*]['author']
$..author 
$..['author']
$['store']['book'][2]['title']  

上述表达式含义分别是:

1、$.store.book[*].author —— 在 JSON 对象中,查找所有在“store”对应的 JSON 对象中的“book”对象数组里的每一个对象的“author”属性;

2、$.['store']['book'][*]['author'] —— 与前者等价;

3、$..author —— 查找 JSON 对象中的“author”属性,不限定它在哪一个对象层次之下;

4、$..['author'] —— 与前者等价;

5、$['store']['book'][2]['title'] —— 返回第三个“book”对象的“title”属性。

二、JSONPath筛选器

JSONPath 表达式还提供了一些简单的比较运算符如 =、!=、<、<=、>、>=等等,用于筛选数据。下面是一个常见的 JSONPath 表达式:

$.store.book[?(@.price < 10)].title

这个表达式的含义是,在“store”对象的“book”数组里找到属性“price”的值小于 10 的对象,然后返回其“title”字段的值。

三、JSONPath递归下降

JSONPath 的递归下降操作符“..”可以递归地查询一个对象所有儿子节点下的所有内容,非常方便。

$..price 
$..['price']
$.store..price 
$.['store']..['price']

这个表达式的含义是:在这个 JSON 对象里,查找“price”属性,并且不限定在哪一个对象层次之下,只要能够找到就返回。

四、JSONPath筛选器的其他用法

JSONPath 表达式还可以使用多种操作符来进行筛选操作,例如:

$..books[?(@.language == 'en')] 
$..books[?(@.price < 10 && @.category == 'children')] 
$..books[?(@.author =~ /.*some.*/i)] 

这个表达式含义分别是:

1、$..books[?(@.language == 'en')] —— 查找所有图书中,属性“language”等于“en”的图书;

2、$..books[?(@.price < 10 && @.category == 'children')] —— 查找所有价格小于 10,且分类为“children”的图书;

3、$..books[?(@.author =~ /.*some.*/i)] —— 查找所有作者名称中包含“some”的图书,不分大小写。

五、结束语

本文简单介绍了 JSONPath 的一些基本语法和操作符,这些操作符使用起来非常灵活,可以满足我们对 JSON 数据的一些非常常见的操作,如数据查询、数据遍历、数据筛选等操作。相信通过本文的阅读,大家对于 JSONPath 表达式的使用会有更深的认识与掌握!