学会这个Python库,接口测试快速攻破!

我们在做接口测试时,大多数返回的都是json属性,我们需要通过接口返回的json提取出来对应的值,然后进行做断言或者提取想要的值供下一个接口进行使用。

但是如果返回的json数据嵌套了很多层,通过查找需要的词,就很不方便,小编今天介绍一种python的第3方库jsonpath。

jsonpath

jsonpath是使用一种简单的方法来提取给定JSON内容。在我们做接口测试时,目前流行的数据格式就是JSON格式的,当碰到复杂JSON格式时,我们可以使用JsonPath快速提取数据或者更新数据。

安装:pip install jsonpath。

小编先通过正常的接口,获取一段json数据供我们进行测试使用:

  1. import requests

  2. # 请求天气的url地址

  3. url= 'http://apis.juhe.cn/simpleWeather/query'

  4. # 请求参数

  5. data = {

  6. "city":"上海",

  7. "key":"331eab8f3481f37868378fcdc76cb7cd"

  8. }

  9. # 发送post请求

  10. r = requests.post(url,data=data)

  11. j = r.json()

  12. print(j)

通过执行后,获取一段我们想要的json数据。

  1. {

  2. "reason":"查询成功!",

  3. "result":{

  4. "city":"上海",

  5. "realtime":{

  6. "temperature":"23",

  7. "humidity":"25",

  8. "info":"多云",

  9. "wid":"01",

  10. "direct":"西北风",

  11. "power":"2级",

  12. "aqi":"58"

  13. },

  14. "future":[

  15. {

  16. "date":"2023-03-15",

  17. "temperature":"10/23℃",

  18. "weather":"多云",

  19. "wid":{

  20. "day":"01",

  21. "night":"01"

  22. },

  23. "direct":"西南风转东北风"

  24. },

  25. {

  26. "date":"2023-03-16",

  27. "temperature":"9/15℃",

  28. "weather":"多云转小雨",

  29. "wid":{

  30. "day":"01",

  31. "night":"07"

  32. },

  33. "direct":"东南风"

  34. },

  35. {

  36. "date":"2023-03-17",

  37. "temperature":"9/13℃",

  38. "weather":"中雨转小雨",

  39. "wid":{

  40. "day":"08",

  41. "night":"07"

  42. },

  43. "direct":"东南风转北风"

  44. },

  45. {

  46. "date":"2023-03-18",

  47. "temperature":"8/15℃",

  48. "weather":"多云",

  49. "wid":{

  50. "day":"01",

  51. "night":"01"

  52. },

  53. "direct":"北风转东南风"

  54. },

  55. {

  56. "date":"2023-03-19",

  57. "temperature":"12/16℃",

  58. "weather":"晴",

  59. "wid":{

  60. "day":"00",

  61. "night":"00"

  62. },

  63. "direct":"东南风"

  64. }

  65. ]

  66. },

  67. "error_code":0

  68. }

通过下标提取

json数据有了,那么我们先用正常提取json的方法,进行提取3-16日的天气信息,看看如何提取。

可以看到我们想要提取需要找到对应的值,然后在继续往下一层一层的查找,如果嵌套层数过多,容易出错,返回信息格式发生改变,这里需要修改信息。

通过jsonpath提取

同样的json数据,我们通过jsonpath进行提取:

  1. data = jsonpath.jsonpath(result,'$..[?(@.date=="2023-03-16")]')

  2. print(data)

  3. -----------------------------输出结果----------------------------

  4. [{'date': '2023-03-16', 'temperature': '9/15℃', 'weather': '多云转小雨', 'wid': {'day': '01', 'night': '07'}, 'direct': '东南风'}]

通过上面的内容会发现,我们直接通过过滤器的方式来讲我们的数据取出来了。有点类似我们的正则表达式。

jsonpath的其他用法

上面介绍的只是jsonpath的一个用法,下面小编介绍几种jsonpath的其他用法。

通过$获取属性值内容

  1. # 直接获取到future的内容

  2. data = jsonpath.jsonpath(result,'$.result.future')

  3. data1 = jsonpath.jsonpath(result,'$.reason')

  4. print(data)

  5. print(data1)

  6. -----------------------------输出结果----------------------

  7. [[{'date': '2023-03-15', 'temperature': '10/23℃', 'weather': '多云', 'wid': {'day': '01', 'night': '01'}, 'direct': '西南风转东北风'}, {'date': '2023-03-16', 'temperature': '9/15℃', 'weather': '多云转小雨', 'wid': {'day': '01', 'night': '07'}, 'direct': '东南风'}, {'date': '2023-03-17', 'temperature': '9/13℃', 'weather': '中雨转小雨', 'wid': {'day': '08', 'night': '07'}, 'direct': '东南风转北风'}, {'date': '2023-03-18', 'temperature': '8/15℃', 'weather': '多云', 'wid': {'day': '01', 'night': '01'}, 'direct': '北风转东南风'}, {'date': '2023-03-19', 'temperature': '12/16℃', 'weather': '晴', 'wid': {'day': '00', 'night': '00'}, 'direct': '东南风'}]]

  8. ['查询成功!']

通过【*】获取对应值

通过上面的json值,获取到关于date的时间值。

  1. data = jsonpath.jsonpath(result, '$.result.future.[*].date')

  2. print(data)

  3. -----------------------------输出结果----------------------

  4. ['2023-03-15', '2023-03-16', '2023-03-17', '2023-03-18', '2023-03-19']

通过切片获取对应值

  1. data = jsonpath.jsonpath(result, '$..future[0,1]')

  2. print(data)

  3. -----------------------------输出结果----------------------

  4. [{'date': '2023-03-15', 'temperature': '10/23℃', 'weather': '多云', 'wid': {'day': '01', 'night': '01'}, 'direct': '西南风转东北风'}, {'date': '2023-03-16', 'temperature': '9/15℃', 'weather': '多云转小雨', 'wid': {'day': '01', 'night': '07'}, 'direct': '东南风'}]

以上只是小编简单的介绍几种jsonpath的使用方法,具体的使用需要大家通过项目上进行结合使用,这里小编在推荐一个jsonpath的调试器,我们可以通过调试器进行查看编写是否正确

http://www.atoolbox.net/Tool.php?Id=792。

小编通过简单的案例进行介绍了如何通过jsonpath进行提取json数值,方面我们在做接口测试对于json的数据进行解析,文章中没有太多的知识点,主要是熟能生巧,经常使用,这样在项目中才能灵活运用。感谢您的阅读,希望对您有所帮助。

总结:

感谢每一个认真阅读我文章的人!!!

作为一位过来人也是希望大家少走一些弯路,如果你不想再体验一次学习时找不到资料,没人解答问题,坚持几天便放弃的感受的话,在这里我给大家分享一些自动化测试的学习资源,希望能给你前进的路上带来帮助。

软件测试面试文档

我们学习必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有字节大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。

 

          视频文档获取方式:
这份文档和视频资料,对于想从事【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!以上均可以分享,点下方小卡片即可自行领取。

  • 19
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值