首页 前端知识 Jsonpath - 数据中快速查找和提取的强大工具

Jsonpath - 数据中快速查找和提取的强大工具

2024-06-03 12:06:05 前端知识 前端哥 881 93 我要收藏

JSON(JavaScript Object Notation)在现代应用程序中广泛使用,但是如何在复杂的JSON数据中 查找和提取所需的信息呢? JSONPath是一种功能强大的查询语言,可以通过简单的表达式来快速准确地定位和提取JSON数据。本文将介绍JSONPath的基本语法和用法,并为您展示如何封装和使用JSONPath方法来处理和操作JSON数据。

随着互联网和移动应用的高度发展,JSON已成为一种常见的数据交换格式。在处理JSON数据时,经常需要从复杂结构中提取特定的值或对象。传统的遍历和条件语句方法可能显得繁琐且低效。 JSONPath提供了一种更简洁、灵活和高效的方式来查询、定位和提取JSON数据中的内容。

01 JSONPath语法

JSONPath采用类似XPath的语法,使用表达式来描述所需的查询和操作。

以下是一些常用的JSONPath表达式示例:

$:表示根元素

$.key:选择根元素下的指定键名的值

$.*:选择根元素下的所有属性值

$.array[*]:选择根元素中的数组的所有元素

$.key[subkey]:选择根元素中的键名为key,子键名为subkey的值

$.key[*].subkey:选择根元素中的键名为key的所有元素的子键名为subkey的值

过滤表达式:

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的封装示例:

  1. import json

  2. def jsonpath(expr, data):

  3. result = []

  4. if expr.startswith("$."):

  5. expr = expr[2:]

  6. def rocess_data(expr, data):

  7. if isinstance(data, dict):

  8. for key,value in data.items():

  9. if key == expr:

  10. result.append(value)

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

  12. process_data(expr, value)

  13. elif isinstance(data, list):

  14. for item in data:

  15. process_data(expr, item)

  16. try:

  17. json_data = json.loads(data)

  18. process_data(expr, json_data)

  19. except json.JSONDecodeError:

  20. print("Invalid JSON data")

  21. return result

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

03 使用封装的JSONPath方法

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

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

  1. data = """

  2. {

  3. "store": {

  4. "book": [

  5. {

  6. "category": "reference",

  7. "author": "Nigel Rees",

  8. "title": "Sayings of the Century",

  9. "price": 8.95

  10. },

  11. {

  12. "category": "fiction",

  13. "author": "Evelyn Waugh",

  14. "title": "Sword of Honour",

  15. "price": 12.99

  16. }

  17. ],

  18. "bicycle":{

  19. "color": "red",

  20. "price": 19.95

  21. }

  22. }

  23. }

  24. """

  25. expression = "$.store.book[0].title"

  26. result = jsonpath(expression, data)

  27. print(result) # 输出: ['Sayings of the Century']

在上述示例中,我们定义了一个JSON数据字符串,并使用封装的jsonpath方法查询JSON数据中的特定值。将表达式$.store.book[0].title作为参数传递给jsonpath方法,它会返回匹配到的结果列表。

总结本文介绍了JSONPath的基本语法和用法,并为您展示了如何封装和使用JSONPath方法来处理和操作JSON数据。通过封装JSONPath方法,我们可以更方便地进行数据查询和提取,提高处理JSON数据的效率和代码可读性。请根据实际需求在不同编程语言中进行相应的封装和使用,以实现更加灵活和便捷的JSON数据处理。

 

总结:

感谢每一个认真阅读我文章的人!!!

作为一位过来人也是希望大家少走一些弯路,如果你不想再体验一次学习时找不到资料,没人解答问题,坚持几天便放弃的感受的话,在这里我给大家分享一些自动化测试的学习资源,希望能给你前进的路上带来帮助。

软件测试面试文档

我们学习必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有字节大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。

 

          视频文档获取方式:
这份文档和视频资料,对于想从事【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!以上均可以分享,点下方小卡片即可自行领取。

转载请注明出处或者链接地址:https://www.qianduange.cn//article/10678.html
标签
linux
评论
发布的文章

JQuery中的load()、$

2024-05-10 08:05:15

大家推荐的文章
会员中心 联系我 留言建议 回顶部
复制成功!