01、Jsonpath的定义
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在线解析工作如下:
04、jsonpath语法
接下来我们来讲解一下常用的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
如果表达式书写不对,会显示匹配不成功,如下图所示
需求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的解析。所以大家都做练习,好好掌握。
最后感谢每一个认真阅读我文章的人,看着粉丝一路的上涨和关注,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走!
软件测试面试小程序
被百万人刷爆的软件测试题库!!!谁用谁知道!!!全网最全面试刷题小程序,手机就可以刷题,地铁上公交上,卷起来!
涵盖以下这些面试题板块:
1、软件测试基础理论 ,2、web,app,接口功能测试 ,3、网络 ,4、数据库 ,5、linux
6、web,app,接口自动化 ,7、性能测试 ,8、编程基础,9、hr面试题 ,10、开放性测试题,11、安全测试,12、计算机基础
资料获取方式 :