在处理 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']
上述表达式含义分别是:
$.store.book[*].author
—— 在 JSON 对象中,查找所有在“store”对应的 JSON 对象中的“book”对象数组里的每一个对象的“author”属性;$.['store']['book'][*]['author']
—— 与前者等价;$..author
—— 查找 JSON 对象中的“author”属性,不限定它在哪一个对象层次之下;$..['author']
—— 与前者等价;$['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)]
这个表达式含义分别是:
$..books[?(@.language == 'en')]
—— 查找所有图书中,属性“language”等于“en”的图书;$..books[?(@.price < 10 && @.category == 'children')]
—— 查找所有价格小于 10,且分类为“children”的图书;$..books[?(@.author =~ /.*some.*/i)]
—— 查找所有作者名称中包含“some”的图书,不分大小写。
五、结束语
本文简单介绍了 JSONPath 的一些基本语法和操作符,这些操作符使用起来非常灵活,可以满足我们对 JSON 数据的一些非常常见的操作,如数据查询、数据遍历、数据筛选等操作。相信通过本文的阅读,大家对于 JSONPath 表达式的使用会有更深的认识与掌握!