【jmespath】—1. 基础用法

简介: 【jmespath】—1. 基础用法

一、jsonpath


之前我写接口自动化测试时候,对于复杂的json返回,会使用jsonpath这个第三方库,就像写xpath一样,方便的查询json元素。


因为之前写WEB自动化时候,总用xpath去查找元素,所以用起来非常顺手。


这里是github上的链接,感兴趣的童鞋也可以去学习一下:jsonpath


二、jmespath


不过httprunner使用的是另一个第三方库jmespath,这个我还是第一次听。大概看了下好像也很不错,这里是github链接和官方教程。


github地址

官方教程


1. 基础表达式


①. 对于字典,可以直接输入key来获取到对应的value。(注意,search是jmespath提供的查询方法,第一个参数是查询语法,第二个则是要查询的数据)


import jmespath
dic_1 = {"a": "foo", "b": "bar", "c": "baz"}
path = jmespath.search("a", dic_1)
print(path)
#运行结果
D:\Daily\whatisyeild>python jmespath_demo.py
foo


如果索引的key不存在,那么会返回null,或者等效于null的语言,比如在Python中返回就是None。


import jmespath
dic_1 = {"a": "foo", "b": "bar", "c": "baz"}
path = jmespath.search("d", dic_1)
print(path)
#运行结果
D:\Daily\whatisyeild>python jmespath_demo.py
None


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


import jmespath
dic_1 = {"a": {"b": {"c": {"d": "value"}}}}
path = jmespath.search("a.b.c.d", dic_1)
print(path)
#运行结果
D:\Daily\whatisyeild>python jmespath_demo.py
value


同样,如果引用的键不存在,则返回null值。


2. 切片


①. 对于一个列表[],可以直接用下标查询,类似于python中list元素访问。(注意,索引基于0开始的)


import jmespath
# dic_1 = {"a": {"b": {"c": {"d": "value"}}}}
list_1 = ["a", "b", "c", "d", "e", "f"]
path = jmespath.search("[1]", list_1)
print(path)
#运行结果
D:\Daily\whatisyeild>python jmespath_demo.py
b


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


import jmespath
dic_1 = {"a": {
          "b": {
            "c": [
              {"d": [0, [1, 2]]},
              {"d": [3, 4]}
            ]
          }
}}
path = jmespath.search("a.b.c[0].d[1][0]", dic_1)
print(path)
#运行结果
D:\Daily\whatisyeild>python jmespath_demo.py
1


③. 列表的切片操作,在这里也可以适用:


import jmespath
dic_1 = {"a": {
          "b": {
            "c": [
              {"d": [0, [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]]},
              {"d": [3, 4]}
            ]
          }
}}
path = jmespath.search("a.b.c[0].d[1][5:10]", dic_1)
print(path)
#运行结果
D:\Daily\whatisyeild>python jmespath_demo.py
[5, 6, 7, 8, 9]


如果切片参数里的步长是负数,则可以反向切片:


import jmespath
dic_1 = {"a": {
          "b": {
            "c": [
              {"d": [0, [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]]},
              {"d": [3, 4]}
            ]
          }
}}
path = jmespath.search("a.b.c[0].d[1][::-2]", dic_1)#步长是负数
print(path)
#运行结果
D:\Daily\whatisyeild>python jmespath_demo.py
[9, 7, 5, 3, 1]


上面是一些常规的用法,但是jmespath还提供了一个更强大的核心功能:Projections,可以应用于元素集合的表达式,这个另起再讲。

相关文章
|
7月前
|
Python
Python中的继承:概念、用法与示例
Python中的继承:概念、用法与示例
76 0
|
1月前
|
安全 数据安全/隐私保护
RememberMe简介及用法
RememberMe简介及用法
33 0
RememberMe简介及用法
|
2月前
|
存储 大数据 Python
案例学Python:filter()函数的用法,高级!
`filter()`函数是Python中处理序列数据的强大工具,它允许我们高效地根据条件过滤元素。通过结合匿名函数、常规函数或直接利用Python的内置逻辑,`filter()`提供了灵活且高效的过滤机制,尤其在大数据处理和内存敏感的应用中展现出其价值。掌握 `filter()`的使用,不仅能提升代码的可读性和效率,还能更好地适应Python的函数式编程风格。
44 2
|
4月前
分析它们的用法与区别
【8月更文挑战第31天】分析它们的用法与区别。
56 1
|
7月前
ThreadHelper用法
ThreadHelper用法
34 0
|
7月前
|
Python
python基础学习 -- 函数高级用法
python基础学习 -- 函数高级用法
30 0
|
XML 前端开发 API
【 ⑧】XPath库及其基本用法
【 ⑧】XPath库及其基本用法
139 0
|
Windows
基础用法
基础用法
105 0
下一篇
DataWorks