Python JsonPath提取输出字典值、获取文件相对路径、列表去重、判断字符串对称

一、Python中使用JsonPath提取字典中的值

JsonPath是解析Json字符串用的,如果有一个多层嵌套的复杂字典,想要根据key和下标来批量提取value,这是比较困难的,使用jsonpath模块可以解决这个痛点。假设接口返回的json数据如下:

{
    
    
    "code": 200,
    "data": [{
    
    
            "id": 1018,
            "venderNo": "8888"  
    }, {
    
    
            "id": 1788,
            "venderNo": "9999"     
        }
    ],
    "msg": "操作成功",
    "rowCount": 2,
    "pageCount": 1,
    "currentPage": 1
}

接口测试代码如下:

import requests
import json
import jsonpath

res = requests.post(url, data=parameters, headers=headers)
result = json.loads(res.text) #将接口响应文本内容转为字典格式

想获取code的值很简单:res.get(“code”) 即可获取。但是想要第一个venderNo的值,则相对麻烦一点,可以使用以下几种方式:

# 通过查找字典中的key以及list方法中的下标索引
venderNo = res.get("data")[0].get("venderNo")
print(venderNo) #输出结果是:8888

# 使用jsonpath, 嵌套n层也能取到所有venderNo信息, $表示最外层的{},..表示模糊匹配
venderNo=jsonpath.jsonpath(d,'$..venderNo') 
print(venderNo) #输出结果是list:['8888', '9999']
print(venderNo[0]) #输出结果是:8888

# 精确匹配找到第一个venderNo信息
venderNo = jsonpath.jsonpath(res, "$.data[0].venderNo") 
# 输出结果是list:['8888'],使用venderNo[0]获取值8888
print(venderNo[0]) #输出结果是:8888

更多使用方式,可参看Jsonpath的官方文档:https://goessner.net/articles/JsonPath/

二、Python获取字典中的所有key和value

假设接口测试的json数据文件中,我们定义期望结果如下:

"expectdata": {
    
    
  "code": "200",
  "data[0].venderNo":"8"
}

我们从json文件中拿到expectdata={“code”: “200”, “data[0].venderNo”:“8”},字典格式。想要打印所有的key和value,代码如下:

expectdata={
    
    "code": "200", "data[0].venderNo":"8"}
for item in expectdata.items():
    print("key是:"+item[0])
    print("value是:"+item[1])

测试结果:

在这里插入图片描述
作用:当需要校验expectdata中的所有字段的值和接口返回的值是否一致时,就可能会用到上面的方法。

三、Python获取项目中数据文件的相对路径

在接口自动化测试框架中,我们的代码除了能在本地运行,也要能在不修改代码的前提下在其他的环境下能够运行,比如别人的电脑上、服务器上。

因此我们在接口测试的模块调用中,必须使用相对路径,不能使用诸如:D:\unitTest\resources 这样的绝对路径,因为其他人下载你的工程代码后,不一定是放在D盘下的。代码放在服务器上运行时也会有路径问题。

所以需要能够动态获取文件的相对路径,才能够满足框架的基本要求,比如项目目录结构如下:

在这里插入图片描述
testcases文件夹下的py文件想获取resources文件夹下的json文件中的内容,获取json文件相对路径的代码如下:

# 获取项目根路径
BASE_PATH = os.path.dirname(os.path.dirname(os.path.realpath(__file__)))
# 根路径下再去找到resources文件夹下的test_http_get_data.json文件
data_file_path = os.path.join(BASE_PATH, "resources", "test_http_get_data.json")

最后根据json文件的相对路径,读取文件内容即可。

四、测开常见面试题

1.如何去除列表中的重复元素:
【题目】给出一个列表:lis = [4, 2, 2, 4, 1, 2, 1, 3, 4, 3],去除列表中的重复元素。

def duplicate():
    lis = [4, 2, 2, 4, 1, 2, 1, 3, 4, 3]

    # 解法1: 利用set去重,会改变列表顺序
    lis1 = list(set(lis))

    # 解法2:
    lis2 = []
    for i in lis:
      if i not in lis2:
        lis2.append(i)

    print("lis1的值:", lis1)
    print("lis2的值:", lis2)


if __name__ == '__main__':
    duplicate()

测试结果如下:

在这里插入图片描述

2.判断字符串是否对称:
【题目】给出一个字符串,判断该字符串是否对称

def test_symmetrical(str):
    print("判断的字符串为:",str)
    length = len(str)
    print("字符串长度为:", length)
    for i in range(int(length/2)):
        if str[i] != str[length - i - 1]:
            aaa = str[i]
            bbb = str[length - i - 1]
            print("第{}".format(i+1)+"轮判断失败:"+aaa+"!="+bbb)
            return False
    return True


if __name__ == '__main__':
    input_pwd1 = "12333211"
    print(test_symmetrical(input_pwd1))
    print("==================================")

    input_pwd1 = "1233321"
    print(test_symmetrical(input_pwd1))

测试结果:

在这里插入图片描述

==============================================================================
以上就是本次的全部内容,都看到这里了,如果对你有帮助,麻烦点个赞+收藏+关注,一键三连啦~

欢迎关注下方我的公众号:程序员杨叔,各类文章都会第一时间在上面发布,持续分享全栈测试知识干货,你的支持就是作者更新最大的动力~

猜你喜欢

转载自blog.csdn.net/baidu_28340727/article/details/128656834