Jsonpath - 数据中快速查找和提取的强大工具_使用jsonpath模块时,可以通过以下哪个方法执行查询操作 。

img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上软件测试知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

需要这份系统化的资料的朋友,可以戳这里获取

JSONPath允许使用过滤表达式来筛选符合特定条件的元素。

以下是一些过滤表达式示例:

$.key[?(@.subkey == value)]:选择根元素中key为指定值且具有subkey并且值等于value的元素。

$.array[?(@.value > 10)]:选择根元素中值大于10的数组元素。

范围表达式:

JSONPath支持范围表达式来选择特定的元素范围。

以下是一些范围表达式示例:

$.array[start:end]:选择根元素中从start索引到end索引之间的数组元素。

$.array[:end]:选择根元素中从开头到end索引之间的数组元素。

$.array[start:]:选择根元素中从start索引到末尾的数组元素。

通配符表达式:

JSONPath提供通配符表达式来匹配多个键或数组元素。

以下是一些通配符表达式示例:

$.*:选择根元素下的所有键值对。

$…key:选择根元素和所有子元素中的具有指定键名的值。

操作符表达式:

JSONPath支持许多操作符来进行比较和运算。

以下是一些操作符表达式示例:

$.key[?(@.value > 10 && @.value < 20)]:选择根元素中值大于10且小于20的key。

$.key[?(@.name =~ /pattern/)]:选择根元素中name符合正则表达式pattern的key。

02 封装JSONPath方法

为了更方便地使用JSONPath,我们可以封装一个方法来处理和操作JSON数据。

下面是一个Python的封装示例:

import json

 

def jsonpath(expr, data):

     result = []

if expr.startswith("$."):

         expr = expr[2:]

 

def rocess_data(expr, data):

         if isinstance(data, dict):

for key,value in data.items():

if key == expr:

                  result.append(value)

elif isinstance(value, (dict, list)):

               process_data(expr, value)

         elif isinstance(data, list):

for item in data:

               process_data(expr, item)



try:

      json_data = json.loads(data)

      process_data(expr, json_data)

except json.JSONDecodeError:

print("Invalid JSON data")



     return result

上述代码中,我们定义了一个jsonpath函数,接受两个参数:expr表示 JSONPath表达式,data表示要处理的JSON数据。封装的方法内部使用递归遍历JSON数据,根据表达式匹配对应的值,并将其添加到结果列表中。最后将结果返回。

03 使用封装的JSONPath方法

通过封装的JSONPath方法,我们可以轻松地进行JSON数据的查询和提取。

以下是一个使用封装方法的示例:

data = """

 {

    "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

     }

    ],

"bicycle":{

     "color": "red",

"price": 19.95

    }



![img](https://img-blog.csdnimg.cn/img_convert/656819ac5392e6d5f1d6e4d2ce7ac22a.png)
![img](https://img-blog.csdnimg.cn/img_convert/938f3bd0a2dfaff74cb8b8a886e001b6.png)

**网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**

**[需要这份系统化的资料的朋友,可以戳这里获取](https://bbs.csdn.net/topics/618631832)**

**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**

,不再深入研究,那么很难做到真正的技术提升。**

**[需要这份系统化的资料的朋友,可以戳这里获取](https://bbs.csdn.net/topics/618631832)**

**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值