JMESPath_正则表达式语法

JMESPath_正则表达式语法前言JMESPath是JSON的查询语言。您可以从JSON文档中提取和转换元素官方文档:https://jmespath.org/tutorial.html基本表达式JMESPath用的最多的

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

前言

JMESPath是JSON的查询语言。您可以从JSON文档中提取和转换元素
官方文档:https://jmespath.org/tutorial.html
 

基本表达式

JMESPath用的最多的方法就是search查询方法,下面是语法结构

search(<jmespath expr>, <JSON document>) -> <return value>
  • jmespath expr:查询的表达式
  • JSON document:查询的数据

除了JMESPath表达式类型之外,JMESPath也支持JSON支持的相同类型

  • number (JSON中的整数和双精度浮点格式)
  • string
  • boolean (true or false)
  • array (有序的值序列)
  • object (键值对的无序集合)
  • null
import jmespath


dict1 = {"a": "foo", "b": "bar", "c": "baz"}
path = jmespath.search("a", dict1)
print(path)

# 结果:
foo

上述代码描述的是从dict1数据中,查找key=a的值
如果索引的key不存在,则返回null,或者等效于null的语言,比如在Python中返回就是None。

import jmespath


dict1 = {"a": "foo", "b": "bar", "c": "baz"}
path = jmespath.search("a1", dict1)
print(path)

# 结果
None

实际中接口的返回值大多是多层嵌套的,比如我要获取最里面一层的value,可以这样查询:

import jmespath


dict1 = {"a": {"b": {"c": {"d": "value"}}}}
path = jmespath.search("a.b.c.d", dict1)
print(path)

# 结果
value

 

索引表达式

①索引表达式可以选择列表中的特定元素。类似于python中的list。

import jmespath


dict1 = ["a", "b", "c", "d", "e", "f"]
path = jmespath.search("[0]", dict1)
print(path)

# 结果
a

②如果指定的索引大于列表,则返回null值

import jmespath


dict1 = ["a", "b", "c", "d", "e", "f"]
path = jmespath.search("[10]", dict1)
print(path)

# 结果
None

③字典和列表的嵌套也非常常见,同样查询也可以组合使用

import jmespath


dict1 = {
        "a": {
          "b": {
            "c": [
              {"d": [0, [1, 2]]},
              {"d": [3, 4]}
              ]
            }
          }
        }
path = jmespath.search("a.b.c[0].d[1][0]", dict1)
print(path)

# 结果
1

 

切片

列表的切片操作,python中可以使用的,这里都适用

import jmespath


dict1 = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
path = jmespath.search("[5:10]", dict1)
print(path)

# 结果
[5, 6, 7, 8, 9]

下面展示我们最常用的反向切片

import jmespath


dict1 = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
path = jmespath.search("[::-2]", dict1)
print(path)

# 结果
[9, 7, 5, 3, 1]
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/165575.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 怎么完全卸载赛门铁克_赛门铁克(sep)卸载方法

    怎么完全卸载赛门铁克_赛门铁克(sep)卸载方法卸载SEP(symantecendpointprotection),需要密码怎么办2011年12月08日下午1:50默认密码是symantec,或者Symantec1.点击“开始”->运行(或直接:Window徽标键+R)2.输入smc-stop终止SEP。如果跳出输入密码提示,则打开注册表(Window徽标键+R;输入regedit;敲回车),然后找到HKEY_LOCAL_MAC…

    2022年5月9日
    102
  • openssl 签发证书_keytool生成证书

    openssl 签发证书_keytool生成证书第一步Openssl产生私钥RSA第二步生成公钥第三步创建证书签名请求CSR文件第四步生成证书其它第一步:Openssl产生私钥(RSA)//1、生成私钥$opensslgenrsa-aes128-outfd.key2048GeneratingRSAprivatekey,2048bitlongmodulus….+++……

    2022年9月18日
    3
  • 关于sources.list和apt-get [转载]

    关于sources.list和apt-get [转载]

    2021年11月16日
    50
  • 归一化函数normalize详解_求归一化常数A

    归一化函数normalize详解_求归一化常数A1.归一化归一化就是要把需要处理的数据经过处理后(通过某种算法)限制在你需要的一定范围内。首先归一化是为了后面数据处理的方便,其次是保证程序运行时收敛加快。归一化的具体作用是归纳统一样本的统计分布性。归一化在0-1之间是统计的概率分布,归一化在某个区间上是统计的坐标分布。归一化有同一、统一和合一的意思。归一化的目的,是使得没有可比性的数据变得具有可比性,同时又保持相比较的两个数据之间的相对关系,……

    2022年10月11日
    2
  • js 加载初始化日期

    js 加载初始化日期

    2022年1月3日
    49
  • drupal学习教程(待续)「建议收藏」

    drupal学习教程(待续)「建议收藏」1.drupal模块安装a.安装captcha模块–>模块–>用户贡献的模块–>b.启用captcha模块–>模块–>选择–>保存配置c.汉化captcha模块打开https://localize.drupal.org/translate/languages/zh-hans下载captcha汉化包–>配置–>翻译–>导入b.配置capt

    2022年6月12日
    28

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号