前言
已知一個dict 比如a = {"a":1},另一個dict比如為b = {"a":1,"b":2},如何判斷a是否在與b中。
一般在接口測試的時候,返回的參數比較多的情況,如果一個個字段去校驗,會比較麻煩,那么如何直接拿一個期望的字典放鍵值對,判斷結果里面是否包含期望的值
set實現
set() 函數創建一個無序不重復元素集,可進行關系測試,刪除重復數據,還可以計算交集、差集、並集等。
set的issubset方法,a.issubset(b) :判斷集合 a 的所有元素是否都包含在集合 b 中
a = {"a": 1}
b = {"a": 1, "b": 2}
aa = set(a.items())
print(aa)
bb = set(b.items())
print(bb)
print(aa.issubset(bb))
運行結果
{('a', 1)}
{('a', 1), ('b', 2)}
True
自定義判斷方法
上面方法看似沒什么毛病,但是這里會存在一個問題,因為set是一個無序且不重復的元素集合。元素為不可變對象!
於是我們把a的值換成一個可變對象,如list 或 dict,問題就來了
a = {"a": [1, 2]}
b = {"a": [1, 2], "b": 2}
aa = set(a.items())
再次執行的時候就會報錯
Traceback (most recent call last):
File "D:/demo/b.py", line 4, in <module>
aa = set(a.items())
TypeError: unhashable type: 'list'
a的值換成一個dict類型,也是會報錯TypeError: unhashable type: 'dict'
a = {"a": {"c": 3}}
b = {"a": {"c": 3}, "b": 2}
aa = set(a.items())
於是可以自己寫個函數遍歷去判斷
# 作者-上海悠悠 QQ交流群:717225969
# blog地址 https://www.cnblogs.com/yoyoketang/
def dict_a_in_b(dict_a, dict_b):
'''is dict_a in dict_b, return True/False'''
result = None
for key in dict_a:
if (key in dict_b) and (dict_a[key] == dict_b[key]):
result = True
else:
return False
return result
if __name__ == '__main__':
a = {"a": {"c": 3}}
b = {"a": {"c": 3}, "b": 2}
print(dict_a_in_b(a, b))
實際應用
一般在接口測試的時候,返回的參數比較多的情況,如果一個個字段去校驗,會比較麻煩,那么如何直接拿一個期望的字典放鍵值對,判斷結果里面是否包含期望的值
當請求一個接口的時候,返回的內容如下
{
'code': 0,
'msg': 'success!',
'data': [{"username": "yoyo", "qq": "283340479"}]
}
期望結果里面包含 {'code': 0, 'msg': 'success!'}
# 作者-上海悠悠 QQ交流群:717225969
# blog地址 https://www.cnblogs.com/yoyoketang/
def dict_a_in_b(dict_a, dict_b):
'''is dict_a in dict_b, return True/False'''
result = None
for key in dict_a:
if (key in dict_b) and (dict_a[key] == dict_b[key]):
result = True
else:
return False
return result
# 預期結果
expected = {'code': 0, 'msg': 'success!'}
# 實際結果
actual_result = {
'code': 0,
'msg': 'success!',
'data': [{"username": "yoyo", "qq": "283340479"}]
}
if __name__ == '__main__':
print(dict_a_in_b(expected, actual_result))