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

这篇具有很好参考价值的文章主要介绍了Jsonpath - 数据中快速查找和提取的强大工具。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

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

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
    }
  }
}
"""

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

result = jsonpath(expression, data)
print(result) # 输出: ['Sayings of the Century']

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

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

总结

最后如果你想学习软件测试和需要软件测试资料,欢迎加入笔者的交流群:731789136,里面可以免费领取软件测试+自动化测试资料+软件测试面试宝典+简历模版+实战项目+面试刷题工具和大佬答疑解惑,我们一起交流一起学习!

到了这里,关于Jsonpath - 数据中快速查找和提取的强大工具的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Jayway JsonPath-提取JSON文档内容的Java DSL

    JsonPath是一种能够提取部分JSON文档属性、对象、数组的语法,支持条件过滤、数学运算、字符串处理等功能。JsonPath与JSON文档就像 XPath 表达式与 XML 文档结合使用一样。 由于 JSON 结构通常是匿名的,并不一定和XML一样具有“根成员对象”,因此 JsonPath假定分配$给外层对象的

    2024年02月05日
    浏览(41)
  • 比肩 ChatGPT,国内快速访问的强大 AI 工具 Claude

    作者 :明明如月学长, CSDN 博客专家,蚂蚁集团高级 Java 工程师,《性能优化方法论》作者、《解锁大厂思维:剖析《阿里巴巴Java开发手册》》、《再学经典:《EffectiveJava》独家解析》专栏作者。 热门文章推荐 : (1)《人工智能时代,软件工程师们将会被取代?》 (2)

    2023年04月16日
    浏览(72)
  • 【重新定义matlab强大系列七】利用matlab函数ischange查找数据变化点

    🔗 运行环境:matlab 🚩 撰写作者:左手の明天 🥇 精选专栏:《python》 🔥  推荐专栏:《算法研究》 ####  防伪水印—— 左手の明天 #### 💗 大家好🤗🤗🤗,我是 左手の明天 !好久不见💗 💗今天开启新的系列—— 重新定义matlab强大系列 💗 📆  最近更新:

    2024年02月06日
    浏览(53)
  • 【重新定义matlab强大系列三】MATLAB清洗离群数据(查找、填充或删除离群值)

    🔗 运行环境:matlab 🚩 撰写作者:左手の明天 🥇 精选专栏:《python》 🔥  推荐专栏:《算法研究》 ####  防伪水印—— 左手の明天 #### 💗 大家好🤗🤗🤗,我是 左手の明天 !好久不见💗 💗今天开启新的系列—— 重新定义matlab强大系列 💗 📆 

    2024年02月04日
    浏览(47)
  • 【Git】Git 拉取的快速方法(含项目示例)

    在我们之前的拉取中,速度可能比较慢,例如,我们要拉取CLIP的项目。 我们拉取失败!如下图所示: 我们尝试新的方法: 这个错误表明在尝试从 GitHub 下载文件时,连接超时导致读取操作无法完成。这可能是由于网络连接不稳定或GitHub服务器响应缓慢所致。解决这个问题的

    2024年02月16日
    浏览(45)
  • 递归解析Json,实现生成可视化Tree+快速获取JsonPath

    内部平台的一个小功能点的实现过程,分享给大家: 递归解析Json,可以实现生成可视化Tree+快速获取JsonPath 。 步骤: 1.利用JsonPath读取根,获取JsonObject 2.递归层次遍历JsonObjec,保存结点信息 3.利用zTree展示结点为可视化树,点击对应树的结点即可获取对应结点的JsonPath 示例

    2024年02月08日
    浏览(44)
  • 【EXCEL】快速填充数据,批量提取与组合数据

    目录 0.环境 1.简要介绍功能 2.具体实际应用 1)提取括号中的内容 2)拆分重组--重组“姓”和“职位” 3)数据拆分 windows + office2021 注意: 此功能可能需 excel 2013版本及以上 使用 在excel中,有没有遇到过以下情况,有一列是邮箱(名字+@qq.com组成),我希望提取所有的用户名

    2024年02月11日
    浏览(64)
  • EXCEL 强大的数据分析工具

    Microsoft Excel 是 Microsoft 办公套件的主要部分之一,也是世界上最强大的电子表格软件之一。它使用包含具有各种行和列的表格的电子表格来组织带有公式和函数的数字和数据。它允许在 excel 公式的帮助下使用算术运算轻松处理值。此外,MS Excel 具有强大的编程支持,使其从其

    2024年02月05日
    浏览(82)
  • 【Excel】快速提取某个符号前面的数据内容

    【问题描述】 在使用excel整理数据过程中,经常与需要调整数据后,进行使用。 例如凭证导出后,科目列是包含科目编码和科目名称的。 但由于要将数据复制到其他的导入模板上使用,对应的模板只需要科目编码,不需要科目名称。 所以需要将导出的数据进行修改后使用,

    2024年02月07日
    浏览(43)
  • 如何在Excel表中快速提取想要的数据

    目录 如何在Excel表中快速提取数据 1、例如:需要提取右侧表格中蔬菜二月计划与销售数量 2、在白菜计划数量的单元格中输入函数公式=VLOOKUP(\\\"*\\\"I3\\\"*\\\",$A$2:$G$19,4,FALSE) , 其中I3是指需要查找的单元格内容 白菜 ,$A$2:$G$19是指需要查找的表格范围A2-G19, 4是指第四列D列。 3、白菜计

    2024年02月08日
    浏览(42)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包