网站首页 > 技术文章 正文
每天进步一点点,关注我们哦,每天分享测试技术文章
本文章出自【码同学软件测试】
码同学公众号:自动化软件测试
码同学抖音号:小码哥聊软件测试
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
免费领取 码同学软件测试 课程笔记+超多学习资料+完整视频+最新面试题,可以转发文章 + 私信「码同学666」获取资料哦
需求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的解析。所以大家都做练习,好好掌握。
今日文章留言
Jsonpath的书写语法和python应用jsonpath的语法就讲到这了,大家有任何问题欢迎留言。
END
免费领取码同学软件测试课程笔记+超多学习资料+学习完整视频,可以关注我们公众号哦:自动化软件测试
本文著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。
猜你喜欢
- 2024-11-11 php+json+mysql实现前后端分离(php vue前后端分离)
- 2024-11-11 PHP中json解析失败原因, json_decode返回null解析失败原因
- 2024-11-11 如何使php的数组传递到js中(如何使php的数组传递到js中)
- 2024-11-11 Python操作JSON格式数据的技巧(python解析json数据)
- 2024-11-11 Linux(centos)用yum方式安装php最新版
- 2024-11-11 PHP 8.3 正式发布!(php8.0新功能)
- 2024-11-11 使用json_encode打印中文字符并且格式化(php代码)
- 2024-11-11 PhpStorm 2022.2 已发布(phpstorm2018)
- 2024-11-11 你不知道的PHP 8.3版本和它的一些有趣的变化
- 2024-11-11 通过WordPress HTTP API 获取json内容并解析
- 最近发表
-
- 使用Knative部署基于Spring Native的微服务
- 阿里p7大佬首次分享Spring Cloud学习笔记,带你从0搭建微服务
- ElasticSearch进阶篇之搞定在SpringBoot项目中的实战应用
- SpringCloud微服务架构实战:类目管理微服务开发
- SpringBoot+SpringCloud题目整理
- 《github精选系列》——SpringBoot 全家桶
- Springboot2.0学习2 超详细创建restful服务步骤
- SpringCloud系列:多模块聚合工程基本环境搭建「1」
- Spring Cloud Consul快速入门Demo
- Spring Cloud Contract快速入门Demo
- 标签列表
-
- cmd/c (57)
- c++中::是什么意思 (57)
- sqlset (59)
- ps可以打开pdf格式吗 (58)
- phprequire_once (61)
- localstorage.removeitem (74)
- routermode (59)
- vector线程安全吗 (70)
- & (66)
- java (73)
- org.redisson (64)
- log.warn (60)
- cannotinstantiatethetype (62)
- js数组插入 (83)
- resttemplateokhttp (59)
- gormwherein (64)
- linux删除一个文件夹 (65)
- mac安装java (72)
- reader.onload (61)
- outofmemoryerror是什么意思 (64)
- flask文件上传 (63)
- eacces (67)
- 查看mysql是否启动 (70)
- java是值传递还是引用传递 (58)
- 无效的列索引 (74)