1,JsonPath简介

JaywayJsonPath是一个用于读取JSON文档的Java库,提供了丰富的操作符和函数,如$、@、*、..等。它支持数组过滤、分片、函数计算(如min、max、avg)以及过滤器表达式,如in、nin等。该库适用于复杂JSON数据的处理和查询。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1,Jayway JsonPath

Jayway JsonPath是一个读取json文档的java DSL 实现

github: https://github.com/json-path/JsonPath

2,特点

  • 1,JsonPath表达式根成员对象为$,无论是对象还是数组;
  • 2,表达式可以使用逗点符号($.store.book[0].title)和[]符号表示($['store']['book'][0]['title']);

3,操作符

操作符描述
$查询的根元素,所有路径表达式的开始
@当前节点正在处理的过滤器断言
*通配符,适用于任何地方的名字或数字
..深度扫描,需要一个name
.<name>子节点
['<name>' (, '<name>')][]表示的一个或多个节点
[<number> (, <number>)]数组索引
[start:end]数组分片操作,支持负数
[?(<expression>)]过滤器表达式,必须返回一个布尔值

4,函数

函数在路径的最后执行

函数描述输出类型
min()数字数组的最小值Double
max()数字数组的最大值Double
avg()数字数组的平均值Double
stddev()数字数组的标准方差Double
length()数组的长度Integer
sum()数字数组求和Double
keys()属性的keysSet<E>
concat(X)提供了添加新元素的输出like input
append(X)添加新元素到输出数组中like input

5,过滤器操作符

过滤器使用逻辑表达式对数组进行过滤.复杂的过滤器使用逻辑操作符 && 和 || 组成.字符串字符必须使用单或双引号,例如[?(@.color == 'blue')] or [?(@.color == "blue")]

操作符描述
in左边在右边存在,比如[?(@.size in [‘S’, ‘M’])]
nin左边不在右边存在
subsetof左边是右边的子集,比如[?(@.sizes subsetof [‘S’, ‘M’, ‘L’])]
anyof左边和右边有交集,比如 [?(@.sizes anyof [‘M’, ‘L’])]
noneof左边和右边没有交集,比如 [?(@.sizes noneof [‘M’, ‘L’])]
size左边数组或字符串大小和右边匹配
empty左边数组或字符串为空
==左边等于右边 (注意,1 不等于’1’)
!=左边不等于右边
<左边小于右边
<=左边小于等于右边
>左边大于右边
>=左边大于等于右边
=~左边匹配右边的正则表达式,比如[?(@.name =~ /foo.*?/i)]
### 接口自动化测试中的JsonPath语法使用 #### JsonPath简介 JsonPath是一种用于解析JSON文档并从中提取所需数据的语言工具。它类似于XPath,但专为JSON设计。通过JsonPath表达式可以方便地定位和获取嵌套结构中的特定字段或值[^1]。 #### 支持的编程语言 JsonPath被广泛应用于多种主流编程语言环境之中,其中包括但不限于JavaScript、Java、Python以及PHP等。这使得开发者可以根据自己的技术栈灵活选用合适的实现方式来处理JSON数据。 #### Python中JsonPath的应用场景 在Python接口自动化的上下文中,当涉及到API返回的数据为JSON格式时,经常需要用到参数提取功能来进行后续操作或者验证响应内容是否符合预期。此时,利用JsonPath能够高效完成这些任务而不必编写复杂的逻辑代码[^3]。 #### 安装与基本用法 为了能够在项目里运用JsonPath库,在开始之前需要先将其安装至本地环境中。可以通过pip包管理器执行如下命令完成依赖项引入:`pip install jsonpath` 。之后便可以在脚本文件顶部导入该模块并通过调用相应方法实现目标检索工作。例如下面展示了一个简单的例子说明如何基于给定对象obj按照指定模式expr查找匹配的结果集: ```python import jsonpath res = jsonpath.jsonpath(obj, expr) ``` #### 实际案例分析 假设我们有一个这样的JSON字符串表示了一组书籍的信息列表: ```json { "store": { "book": [ {"category":"fiction","title":"The Great Gatsby"}, {"category":"non-fiction","title":"Sapiens"} ], "bicycle":{"color":"red", "price":19.95} } } ``` 如果我们想找出所有属于小说类别的书名,则对应的JsonPath查询语句应该是 `$..book[?(@.category=='fiction')].title` ,最终得到的是 `["The Great Gatsby"]` 这样的数组形式输出结果[^4]。 #### 注意事项 尽管JsonPath提供了强大的能力帮助简化复杂的数据访问过程,但在实际开发过程中也需要注意一些细节问题以免造成不必要的麻烦。比如确保输入源确实遵循标准JSON规范;合理设置过滤条件避免误判等情况发生等等[^2]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值