学会了JsonPath,你的Python接口脚本才算完整

每天进步一点点,关注我们哦,每天分享测试技术文章

本文章出自【码同学软件测试】

码同学公众号:自动化软件测试,领取资料可加:magetest

码同学抖音号:小码哥聊软件测试

01Jsonpath的定义

JsonPath是一种简单的方法来提取给定JSON文档的部分内容。Jsonpath是跨语言的,很多语言都可以使用jsonpath,如Javascript,Python和PHP,Java。

 

JsonPath提供的json解析非常强大,它提供了类似正则表达式的语法,基本上可以满足所有你想要获得的json内容。

02案例

我们拿一个免费的地图接口为例,以下是接口的对应的内容:

Url地址:https://ditu.amap.com/service/regeo?longitude=121.04925573429551&latitude=31.315590522490712

请求方法:get请求

响应数据:json数据

03工具准备

pycharm,json在线解析工具,jsonpath在线解析工具

Pycharm是python的编辑工具,这个大家自行下载

Json在线解析工具,网址如下:https://www.sojson.com/

jsonpath在线解析工具,网址如下:http://www.e123456.com/aaaphp/online/jsonpath/

 

因为响应结果的json数据如果很多,不是特别好看如何提取对应的数据,这时候可以利用json的在线解析工具,但是json数据的特点就是键被双引号包裹的。Reqeusts库获取的响应值是resp,他的resp.json()获取的是字典的类型,resp.text获取的是json字符串,所以把resp.text获取的数据粘贴到工具中进行转换,代码如下:

 

 

 

Json在线转换如图所示:

 

 

Jsonpath在线解析工作如下:

 

 

 

04jsonpath语法

接下来我们来讲解一下常用的jsonpath的语法,其他的可以参考上面图片的JSONPATH expressions:

$  代表整个json数据的值

.  代表的是层级关系,类似windows电脑的/

.. 代表相对的层级关系,类似windows电脑的//

[索引]  如果是列表中获取其中的元素,就通过列表中的额索引值进行获取,索引值是从0开始的。

[0,1] 或者[start:end] 可以对列表进行切片获取对应的元素

[?(@.price)]  获取带有对应属性的键

 

[?(@.price<10)]  获取带有对应属性且对应属性的值具有某些特点的键

 

需求1:获取cross_list里面所有的name的值

$..name

 

 

 

 

需求2:获取cross_list中第二个元素的name值

$.data.cross_list[1].name

 

 

如果表达式书写不对,会显示匹配不成功,如下图所示

免费领取码同学软件测试课程笔记+超多学习资料+完整视频+面试题,可加微信:magetest

 

 

 

 

需求3:获取cross_list中前两个元素的name值

$.data.cross_list[:2].name

 

 

 

 

需求4:找出poi_list这个键所对应的值里面包含具有direction属性的值

$.data.poi_list[?(@.direction)]

 

 

 

 

需求5:找出cross_list的值里面的weight等于”130”的值

$.data.cross_list[?(@.weight=="130")]

 

 

Python如何使用jsonpath:

首先下载python的第三方库

pip install jsonpath

Jsonpath的语法如下:

jsonpath.jsonpath()

参数:json对象,jsonpath表达式

返回值:列表

用python去解析jsonpath的代码如下

 

 

 

备注:jsonpath获取匹配到的结果都放在列表中保存,所以想得到里面的数据一定是要用索引值进行获取的。

 

因为json的跨语言和方便性,很多开发人员写的接口都比较喜欢返回json数据,所以我们在做接口自动化测试的时候经常会遇到对json数据进行解析的时候,比如对响应数据做断言,或者有接口依赖的场景的时候,需要做数据提取,这两种情况都会遇到jsonpath的解析。所以大家都做练习,好好掌握。

免费领取码同学软件测试课程笔记+超多学习资料+学习完整视频 ☞ 可加:magetest/关注码同学公众号:自动化软件测试

本文著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。

posted @ 2022-08-25 09:27  码同学软件测试  阅读(27)  评论(0编辑  收藏  举报