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

在人间换酒钱 2022-11-08 04:32:16 阅读数:175

Python接口学会会了jsonpath

Jsonpath的定义

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

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

案例

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

Url地址:longitude=121.04925573429551&latitude=31.315590522490712

请求方法:get请求

响应数据:json数据

工具准备

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在线解析工作如下:

jsonpath语法

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

$ 代表整个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


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


需求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的解析。所以大家都做练习,好好掌握。

最后,为方便大家学习【自动化测试】特意给大家准备了一份13G的超实用干货学习资源,涉及的内容非常全面。


包括软件学习路线图,50多天的上课视频、16个突击实战项目,80余个软件测试用软件,37份测试文档,70个软件测试相关问题,40篇测试经验级文章,上千份测试真题分享,还有2022软件测试面试宝典,还有软件测试求职的各类精选简历,希望对大家有所帮助……

需要的小伙伴点击下方插件进群免费领取:

版权声明:本文为[在人间换酒钱]所创,转载请带上原文链接,感谢。 https://blog.csdn.net/m0_53918927/article/details/127740790