解析json数据--JMESPath模块
第一part:JMESPath 简介
JMESPath 是 JSON的查询语言,可以从JSON文档中提取和转换元素,类似于 jsonpath 的另外一个库。 |
第二part:python安装jmespath模块
pip install jmespath |
第三part:python使用jmespath模块
jmespath.search(expression,data)方法的使用:其中参数expression为表达式,data为json数据。
在接口自动化中,可以使用该方法进行获取json的数据进行断言。
json数据为:
data={
"status": {
"code": 0,
"message": "ok"
}
}
|
例如:
#导包 #返回joson数据中的status中的数据: get_data=jmespath.search('status',data) 运行结果:
|
第四part:基本表达式
1.【字典取值,根据key名称取到对应】
2.【嵌套的字典,通过一层一层取值】
3.【list(列表)通过下标取值】
4.【dict(字典)嵌套list(列表),通过一层一层的取值】
5.【切片】
切片与python中的字符串切片的使用方法是一致的,是通过索引来获取数据。
切片的一般形式是[start:stop:step]
注意:
start:开始索引,是包含的,为空,代表从0开始
stop:结束索引,是不包含的,为空,代表到最后一个;
step:步长,如果不传,默认为1
5.1 [0:5]
5.2 [5:10]
5.3 [:5],开始索引与步长均为空
5.4 [::2],开始与结束索引均为空,步长为2
5.5 [::-1],步长值为负,则以相反顺序创建切片
6.【列表取值使用 * 通配符】
6.1.取出列表中所有的 first 对应的名称,使用表达式:people[*].first
6.2.取出列表中前 2 个 first 对应的名称,使用表达式:people[:2].first
7.【对象取值使用 * 通配符】
取出 ops 对象的任意属性对应的numArgs,使用表达式: ops.*.numArgs
8.【子查询使用 * 通配符】
8.1 在查询的结果中继续使用 * 通配符,查询的结果是列表的列表(列表嵌套列表)
8.2 通常我们需要的结果是['running', 'stopped', 'terminated', 'running'],只需要一个列表的状态,则使用[],而不是[*]
9.【过滤器使用】
过滤器表达式是数组形式的,其一般形式为 [?<表达式> <比较器> <表达式>]
。
常用的比较表达式可以使用 ==
, !=
, <
, <=
, >
, > =
9.1如下有一个机器列表,每个机器都有一个名称和一个 state,此时想要所有state为running的计算机的名称,使用表达式:machines[?state=='running'].name
10.【管道表达式】
前面在匹配list里面的多个值时候,查询的结果是一个list,如果需要取出结果里面的第n个可以使用管道符 |
例子:取出people下所有对象的 first 属性,从结果里面取第一个值,使用表达式:people[*].first | [0]
11.【多选】
多选列表和多选哈希创建JSON元素,可以创建JSON文档中不存在的元素。
多选列表创建一个列表,多选哈希创建一个JSON对象。
例子:取出people属性的name,以及state中的name值,使用表达式:people[].[name, state.name]
解析:在上面的表达式中,[name, state.name]部分是一个多选列表。它说要创建一个由两个元素组成的列表,第一个元素是针对list元素评估名称表达式的结果,第二个元素是对state.name评估的结果。因此,每个列表元素将创建一个两个元素列表,并且整个表达式的最终结果是两个元素列表的列表。
多重选择具有与多重选择列表相同的基本概念,不同之处在于它会创建哈希而不是数组。
使用上面的相同示例,如果我们想创建一个具有两个键Name和 State的两个元素哈希,则使用表达式:people[].{Name: name, State: state.name}
12.【函数的使用】
JMESPath支持函数表达式。
12.1 函数可用于以强大的方式转换和过滤数据。可以在此处找到函数的完整列表,并且函数表达式规范具有完整的详细信息。
例子1:在people数组中打印数组的长度,使用表达式:
例子2:在people数组中打印最老的人的名字,使用表达式:max_by(people, &age).name
12.2 函数也可以与过滤器表达式组合。在下面的示例中,JMESPath表达式在myarray中查找包含字符串foo的所有元素。
使用表达式:myarray[?contains(@, 'foo') == `true`]
【解析】:
上面示例中的@字符表示在myarray中正在评估的当前元素。如果myarray数组中的当前元素包含字符串 foo , 则包含(@,’foo’)的表达式将返回 true。
尽管函数表达式规范包含所有详细信息,但在使用函数时,需要牢记以下几点:
函数参数具有类型。如果函数的参数类型错误,则会发生无效类型错误。有一些函数可以进行类型转换(to_string,to_number),以帮助将参数转换为正确的类型。