JsonPath 教程

JsonPath 教程

JsonPath 的介绍

JsonPath 是一种简单的方法来提取给定 JSON 文档的部分内容。 JsonPath 有许多编程语言,如 Javascript、Python、PHP 和 Java。

JsonPath 提供的 json 解析能力非常强大,它提供了类似正则表达式的语法,基本上可以满足所有你想要获得的 json 内容。

github 上有 JsonPath 的应用:JsonPath

JsonPath 可以在 Central Maven 仓库中找到,可以看到最新版本已经到了2.4.0。

在这里插入图片描述

JsonPath 的使用

类似于 XPath 在 xml 文档中的定位,JsonPath 表达式通常是用路径检索或设置 Json 的。

JsonPath 中的 “根成员对象” 始终称为$,无论是对象还是数组。

JsonPath表达式可以使用点表示法

$.store.book[0].title

或括号表示法

$['store']['book'][0]['title']

JsonPath 操作符

符号描述
$查询的根节点对象,用于表示一个json数据,可以是数组或对象
@过滤器断言(filter predicate)处理的当前节点对象,类似于java中的this字段
*通配符,必要时可用任何地方的名称或数字
可以理解为递归搜索,必要时在任何地方可以使用名称
.表示一个子节点
[‘’ (, ‘’)]表示一个或多个子节点
[ (, )]表示一个或多个数组下标
[start:end]数组片段,区间为[start,end),不包含end
[?()]过滤器表达式,表达式结果必须是boolean

JsonPath 函数

函数可以在路径的尾部调用,函数的输出是路径表达式的输出,该函数的输出是由函数本身所决定的。

名称描述输出
min()获取数值类型数组的最小值Double
max()获取数值类型数组的最大值Double
avg()获取数值类型数组的平均值Double
stddev()获取数值类型数组的标准差Double
length()获取数值类型数组的长度Integer

JsonPath 过滤器运算符

过滤器是用于筛选数组的逻辑表达式。一个典型的过滤器将是[?(@.age > 18)],其中@表示正在处理的当前项目。 可以使用逻辑运算符&&和||创建更复杂的过滤器。 字符串文字必须用单引号或双引号括起来([?(@.color == ‘blue’)] 或者 [?(@.color == “blue”)]).

操作符描述
==left等于right(注意1不等于’1’)
!=不等于
<小于
<=小于等于
>大于
>=大于等于
=~匹配正则表达式[?(@.name =~ /foo.*?/i)]
in左边存在于右边 [?(@.size in [‘S’, ‘M’])]
nin左边不存在于右边
size(数组或字符串)长度
empty(数组或字符串)为空

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
        }
    },
    "expensive": 10
}
JsonPath表达式结果
$.store.book[*].author 或 $…author[ “Nigel Rees”, “Evelyn Waugh”, “Herman Melville”, “J. R. R. Tolkien” ]
$.store.* 显示所有叶子节点值[ [ { ”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 } ], { ”color” : “red”, ”price” : 19.95 } ]
$.store…price[ 8.95, 12.99, 8.99, 22.99, 19.95 ]
$…book[0,1] 或 $…book[:2][ { ”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 } ]
$…book[-2:]获取最后两本书
$…book[2:][ { ”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 } ]
$…book[?(@.isbn)]所有具有isbn属性的书
$.store.book[?(@.price < 10)]所有价格小于10的书
$…book[?(@.price <= $[‘expensive’])]所有价格低于expensive字段的书
$…book[?(@.author =~ /.*REES/i)]所有符合正则表达式的书 [ { ”category” : “reference”, ”author” : “Nigel Rees”, ”title” : “Sayings of the Century”, ”price” : 8.95 } ]
$…*返回所有
$…book.length()[ 4 ]

测试请点击**测试地址**

JsonPath 常见方法

使用 JsonPath 的最简单的最直接的方法是通过静态读取API。

在这里插入图片描述

如果你只想读取一次,那么上面的代码就可以了

如果你还想读取其他路径,现在上面不是很好的方法,因为他每次获取都需要再解析整个文档。所以,我们可以先解析整个文档,再选择调用路径。

在这里插入图片描述

JsonPath还提供流畅的API。

在这里插入图片描述

JsonPath 调整配置

DEFAULT_PATH_LEAF_TO_NULL

当检索不到时返回null对象,否则如果不配置这个,会直接抛出异常PathNotFoundException

在这里插入图片描述

ALWAYS_RETURN_LIST

如果可以获取到结果则总是返回list,即便是一个确定的非list类型,也会被包装成list;

如果获取不到结果则会报PathNotFoundException异常。

在这里插入图片描述

SUPPRESS_EXCEPTIONS

不抛出异常,需要判断如下:

  • ALWAYS_RETURN_LIST开启,则返回空list

在这里插入图片描述

  • ALWAYS_RETURN_LIST关闭,则返回null

在这里插入图片描述

AS_PATH_LIST

返回path

REQUIRE_PROPERTIES

如果设置,则不允许使用通配符,比如$[*].b,会抛出PathNotFoundException异常。

参考文献:
使用 JSONPath 解析 JSON 完整内容详解

<think>嗯,用户想了解JSONPath的使用教程、示例、语法和解析JSON数据的方法。首先,我需要回忆一下JSONPath的基础知识。JSONPath类似于XPath,用于从JSON结构中提取数据。记得它的语法包括各种操作符,比如根节点$,子节点.或[],递归搜索..,通配符*等等。 用户可能希望看到具体的例子,所以应该准备一个示例JSON数据,然后展示不同的JSONPath表达式如何提取数据。比如,假设有一个包含商店和书籍信息的JSON,可以演示如何获取所有书籍标题、价格高于10的书籍,或者第三本书的信息。 然后,要考虑用户可能遇到的问题,比如如何处理嵌套结构,或者如何使用通配符。另外,用户可能对实际应用中的库感兴趣,比如在Python中使用jsonpath库。需要提到安装方法,并给出代码示例,展示如何加载JSON数据并应用JSONPath表达式。 还要注意引用之前提供的参考资料,比如引用[1]到[4]中的内容,确保信息准确。比如,引用中提到JSONPath类似于XPath,适用于多种语言,包括Python,所以需要强调这些点。 用户可能需要知道语法细节,比如表达式中的运算符和函数,例如使用@表示当前节点,或者使用逻辑表达式过滤数据。此外,递归下降操作符..对于深层嵌套结构很有用,应该举例说明。 最后,常见问题部分可以帮助用户解决实际使用中的困惑,比如表达式无效时检查语法,或者处理大型JSON时的性能问题。还可以提到在线测试工具,方便用户练习和调试。 总结一下,回答的结构应该包括概述、基本语法、示例解析、Python库使用、常见问题,以及相关问题推荐。确保每个部分都有清晰的示例和解释,帮助用户逐步理解和应用JSONPath。</think>### JSONPath 使用教程与语法详解 #### 一、JSONPath 概述 JSONPath 是一种用于定位和提取 JSON 数据元素的查询语言,类似于 XML 的 XPath。它通过简洁的路径表达式实现复杂 JSON 结构的快速查询[^1][^3]。 --- #### 二、基本语法规则 1. **根节点**:`$` 表示 JSON 根对象 2. **子节点**:`.` 或 `[]` 访问子元素(如 `$.store.book` 或 `$['store']['book']`) 3. **递归搜索**:`..` 查找所有层级中的匹配项 4. **通配符**:`*` 匹配任意元素或属性名 5. **索引访问**:`[n]` 获取数组元素(从0开始) 6. **切片操作**:`[start:end:step]` 处理数组子集 7. **逻辑表达式**:`?(@.price > 10)` 过滤条件 --- #### 三、示例解析 假设有如下 JSON 数据: ```json { "store": { "book": [ {"title": "Python入门", "price": 25}, {"title": "算法导论", "price": 45}, {"title": "数据库系统", "price": 12} ], "location": "北京" } } ``` | JSONPath 表达式 | 结果描述 | |----------------|---------| | `$.store.book[*].title` | 获取所有书籍标题 | | `$..book[?(@.price > 10)]` | 价格超过10的书籍 | | `$..book[2]` | 第三本书的完整信息 | --- #### 四、Python 库使用 1. **安装库**: ```bash pip install jsonpath-ng ``` 2. **代码示例**: ```python from jsonpath_ng import parse data = { # 上述示例JSON结构 } # 查找价格低于30的书籍 expression = parse("$..book[?(@.price < 30)]") matches = [match.value for match in expression.find(data)] print(matches) # 输出包含《Python入门》的列表 ``` --- #### 五、常见问题解答 1. **如何处理深层嵌套结构?** 使用递归操作符 `..`,例如 `$..author` 查找所有层级的作者字段 2. **表达式无效时如何排查?** - 检查路径是否完整(特别注意数组索引) - 验证逻辑表达式语法(括号和运算符是否正确) 3. **性能优化建议** 对大型 JSON 数据,优先使用精确路径而非通配符 --- §§ 相关问题 § 1. JSONPath 与 XPath 的核心差异是什么? 2. 如何处理 JSONPath 中的特殊字符字段名? 3. 有哪些在线 JSONPath 测试工具推荐? : JSONPath 的 XPath 式查询特性 [^2]: 多语言支持的实现库 : 嵌套数据查询优势 [^4]: JSON 基础处理函数
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值