在处理 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 表达式的使用会有更深的认识与掌握!