python之JMESPath:JSON 查询语法库示例详解

简介: python之JMESPath:JSON 查询语法库示例详解

JMESPath是一个用于处理和查询JSON数据的查询语法库。它允许您以简单、一致和强大的方式从复杂的JSON结构中提取数据。在本文中,我将为您提供一个详细的JMESPath示例,以便您了解如何使用它。

首先,我将简要介绍JMESPath的基本思想和一些常用的查询操作符,然后我将通过一个具体的示例来说明如何使用JMESPath进行JSON查询。

JMESPath基本思想:

JMESPath的基本思想是使用类似于XPath的路径表达式来指定要从JSON结构中提取哪些数据。它允许您以一致的方式导航和过滤JSON对象和数组。JMESPath支持以下几种操作符:

  1. 点操作符(.): 用于访问JSON对象中的属性或数组中的元素。
  2. 方括号操作符([]): 用于访问JSON数组中的元素,可以使用索引、迭代和过滤数组。
  3. 通配符(*)和多级通配符(**): 用于匹配任意层级的属性或数组元素。
  4. 过滤器(?): 用于根据条件过滤数组元素。
  5. 比较操作符: 支持等于(==)、不等于(!=)、小于(<)、小于等于(<=)、大于(>)和大于等于(>=)等比较操作符。
  6. 逻辑操作符: 支持与(and)、或(or)和非(not)等逻辑操作符。

现在,让我们通过一个具体示例来说明如何使用JMESPath进行JSON查询。

示例:

假设我们有以下JSON数据:

{
  "students": [
    {
      "name": "Alice",
      "age": 18,
      "grades": {
        "math": 90,
        "english": 85,
        "science": 92
      }
    },
    {
      "name": "Bob",
      "age": 20,
      "grades": {
        "math": 75,
        "english": 88,
        "science": 80
      }
    },
    {
      "name": "Charlie",
      "age": 19,
      "grades": {
        "math": 85,
        "english": 92,
        "science": 78
      }
    }
  ]
}

我们将使用JMESPath来执行以下查询操作:

1.提取所有学生的名字和年龄:
students[].{ "name": name, "age": age }

这个查询将返回一个包含所有学生名字和年龄的列表:

[
  {
    "name": "Alice",
    "age": 18
  },
  {
    "name": "Bob",
    "age": 20
  },
  {
    "name": "Charlie",
    "age": 19
  }
]
2.提取所有学生的姓名、科目和对应的分数:
students[].{ "name": name, "grades": grades }

这个查询将返回一个包含所有学生姓名、科目和对应分数的列表:

[
  {
    "name": "Alice",
    "grades": {
      "math": 90,
      "english": 85,
      "science": 92
    }
  },
  {
    "name": "Bob",
    "grades": {
      "math": 75,
      "english": 88,
      "science": 80
    }
  },
  {
    "name": "Charlie",
    "grades": {
      "math": 85,
      "english": 92,
      "science": 78
    }
  }
]
3.提取分数大于90分的学生姓名:
students[?grades.math > `90`].name

这个查询将返回一个包含分数大于90分的学生姓名的列表:

[
  "Alice"
]

以上只是一些基础的JMESPath查询示例,JMESPath还支持更复杂的查询操作。您可以使用JMESPath来过滤、排序、组合和转换JSON数据。以下是一些其他常见的JMESPath查询示例:

4.提取所有学生的平均分数:
students[].{ 
  "name": name, 
  "average_grade": (grades.math + grades.english + grades.science) / 3 
}

这个查询将返回一个包含所有学生姓名和平均分数的列表:

[
  {
    "name": "Alice",
    "average_grade": 89
  },
  {
    "name": "Bob",
    "average_grade": 81
  },
  {
    "name": "Charlie",
    "average_grade": 85
  }
]
5.提取平均分数最高的学生姓名:
students[].{ 
  "name": name, 
  "average_grade": (grades.math + grades.english + grades.science) / 3 
} | max_by(@, &average_grade).name

这个查询将返回平均分数最高的学生姓名:

"Alice"
6.提取每个科目的最高分数:
{
  "math": max(students[].grades.math),
  "english": max(students[].grades.english),
  "science": max(students[].grades.science)
}

这个查询将返回每个科目的最高分数:

{
  "math": 90,
  "english": 92,
  "science": 92
}
7.提取年龄在18到20之间的学生姓名:
students[age >= `18` && age <= `20`].name

这个查询将返回年龄在18到20之间的学生姓名:

[
  "Alice",
  "Bob",
  "Charlie"
]


这些示例演示了JMESPath的一些常见用法,您可以使用更复杂的查询来满足您的需求。JMESPath还有更多功能,如嵌套查询、支持正则表达式、对查询结果进行转换等,您可以参考官方文档以获取更详细的信息。


希望这些示例能够帮助您理解JMESPath的基本概念和用法,以便您能够在Python中轻松使用它进行JSON查询。

 


相关文章
|
8天前
|
JavaScript 前端开发 Java
通义灵码 Rules 库合集来了,覆盖Java、TypeScript、Python、Go、JavaScript 等
通义灵码新上的外挂 Project Rules 获得了开发者的一致好评:最小成本适配我的开发风格、相当把团队经验沉淀下来,是个很好功能……
289 71
|
26天前
|
XML JSON API
淘宝商品详情API的调用流程(python请求示例以及json数据示例返回参考)
JSON数据示例:需要提供一个结构化的示例,展示商品详情可能包含的字段,如商品标题、价格、库存、描述、图片链接、卖家信息等。考虑到稳定性,示例应基于淘宝开放平台的标准响应格式。
|
2月前
|
数据采集 JavaScript Android开发
【02】仿站技术之python技术,看完学会再也不用去购买收费工具了-本次找了小影-感觉页面很好看-本次是爬取vue需要用到Puppeteer库用node.js扒一个app下载落地页-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-优雅草卓伊凡
【02】仿站技术之python技术,看完学会再也不用去购买收费工具了-本次找了小影-感觉页面很好看-本次是爬取vue需要用到Puppeteer库用node.js扒一个app下载落地页-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-优雅草卓伊凡
91 7
【02】仿站技术之python技术,看完学会再也不用去购买收费工具了-本次找了小影-感觉页面很好看-本次是爬取vue需要用到Puppeteer库用node.js扒一个app下载落地页-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-优雅草卓伊凡
|
1月前
|
Python
课时19:Python的基本语法
今天给大家带来分享的是 Python 的基本语法,分为以下六个部分。 1.在 Python 中严格区分大小写 2.Python 中的每一行就是一条语句,每条语句以换行结束 3.Python 中每一行语句不要过长 4.条语句可以分多行编写,语句后边以\结尾 5.Python 是缩进严格的语言,不要随便写缩进 6.在 Python 中使用#来表示注释
|
1月前
|
JSON 监控 API
python语言采集淘宝商品详情数据,json数据示例返回
通过淘宝开放平台的API接口,开发者可以轻松获取商品详情数据,并利用这些数据进行商品分析、价格监控、库存管理等操作。本文提供的示例代码和JSON数据解析方法,可以帮助您快速上手淘宝商品数据的采集与处理。
|
1月前
|
存储 JSON API
淘宝商品详情API接口概述与JSON数据示例
淘宝商品详情API是淘宝开放平台提供的核心接口之一,为开发者提供了获取商品深度信息的能力。以下是技术细节和示例:
|
2月前
|
Web App开发 数据采集 数据安全/隐私保护
Selenium库详解:Python实现模拟登录与反爬限制的进阶指南
Selenium库详解:Python实现模拟登录与反爬限制的进阶指南
|
2月前
|
JSON API 数据格式
淘宝商品评论数据API接口详解及JSON示例返回
淘宝商品评论数据API接口是淘宝开放平台提供的一项服务,旨在帮助开发者通过编程方式获取淘宝商品的评论数据。这些数据包括评论内容、评论时间、评论者信息、评分等,对于电商分析、用户行为研究、竞品分析等领域都具有极高的价值。
|
6月前
|
Python
pip批量安装Python库 requirement.txt 离线环境无互联网环境下pip安装Python库
pip批量安装Python库 requirement.txt 离线环境无互联网环境下pip安装Python库
363 3
|
10月前
|
开发工具 git Python
安装和使用`libnum`是一个用于数字理论函数的Python库
【6月更文挑战第19天】`libnum`是Python的数字理论函数库。安装可通过`git clone`,进入目录后运行`python setup.py install`,也可用`pip install libnum`。示例:使用`int_to_hex`将十进制数42转换为十六进制字符串&#39;2a&#39;。注意,信息可能已过时,应查最新文档以确保准确性。如遇问题,参考GitHub仓库或寻求社区帮助。
175 1
下一篇
oss创建bucket