python-json校驗-jsonpath解析
背景
在進行接口自動化測試的時候,對響應結(jié)果進行校驗,基本上都是對json數(shù)據(jù)的校驗,響應內(nèi)容十分復雜,當然驗證也是一個很龐大的工程 ,不過都是可以通過jsonpath 解決。
JSONPath 提供了強大的 JSON 解析功能,可以更便捷靈活的用來獲取對應的 JSON 內(nèi)容。
表示法
JSONPath 有兩種表示方式, 可以使用點表示法,也可以使用括號表示法
- 點表示法 例子:$.store.book[0].title
- 括號表示法 例子:$['store']['book'][0]['title']
jsonpath的語法
| 語法 | 描述 |
|---|---|
| $ | 根對象/元素 |
| @ | 當前對象/元素 |
| . 或者 [] | 子運算符,匹配下級元素 |
| .. | 遞歸下降,遞歸方式匹配所有子元素 |
| * | 通配符。所有對象/元素,無論其名稱 |
| [] | 下標運算符,jsonpath 從0開始 |
| [,] | 連接的操作符,多個結(jié)果拼接成列表返回 |
| [開始:結(jié)束:步驟] | 從 ES4 借來的數(shù)組切片運算符。 |
| ?() | 應用過濾器(腳本)表達式。 |
| () | 腳本表達式,使用底層腳本引擎。 |
示例
{ "store": {
"book": [
{ "category": "reference",
"author": "Nigel Rees",
"title": "Sayings of the Century",
"price": 8.95
},
{ "category": "fiction",
"author": "Evelyn Waugh",
"title": "Sword of Honour",
"price": 12.99
},
{ "category": "fiction",
"author": "Herman Melville",
"title": "Moby Dick",
"isbn": "0-553-21311-3",
"price": 8.99
},
{ "category": "fiction",
"author": "J. R. R. Tolkien",
"title": "The Lord of the Rings",
"isbn": "0-395-19395-8",
"price": 22.99
}
],
"bicycle": {
"color": "red",
"price": 19.95
}
}
}| jsonpath | 結(jié)果 | 備注 |
|---|---|---|
| $.store.book[*].author | 所有書籍的作者 | |
| $..author | 所有的作者 | |
| $.store.* | 商店下的所有元素/對象,包括書籍和自行車 | |
| $.store..price | 商店里所有元素/對象的價格 | |
| $..book[2] | 下標從0開始,第3本書 | |
| $..book[(@.length-1)] | 按順序排列最后一本書 | 用到了()和@兩個語法 |
| $..book[-1:] | 按順序排列最后一本書 | 用到了[]數(shù)組下標切片 |
| $..book[0,1] | 第1本書和第2本書,前兩本書 | |
| $..book[:2] | 第1本書和第2本書,前兩本書 | $…book[0:2] ,從0開始,0 1,前兩本書 |
| $..book[?(@.isbn)] | 有isbn字段的所有書籍 | |
| $..book[?(@.price<10)] | 所有價格小于10的書籍 | |
| $..* | json結(jié)構(gòu)的所有元素 |
實戰(zhàn)
安裝jsonpath
pip3 install jsonpath
以網(wǎng)上一個開源的獲得天氣的API為例子:
def test_get_json(self):
r = requests.get("http://t.weather.sojson.com/api/weather/city/101191102")
print(r.text)
r_json = r.json()
# 用點方法來獲得notice的內(nèi)容
yesterday = jsonpath(r_json, "$.data.yesterday.notice")
print(yesterday)
# 獲得aqi=15 的forecast元素
aqi = jsonpath(r_json, "$..forecast[?(@.aqi==15)]")
print(aqi)當不知道有jsonpath這個神器的時候,我是通過遍歷一個個元素,然后再去比對具體的字段信息,比如下方:獲得duration 超過7000 的api信息
{
"apis": [{
"path": "/path",
"duration": 7890
}, {
"path": "/path",
"duration": 6890
}, {
"path": "/path",
"duration": 5890
}]
}通過遍歷的方式獲得:
apis = '{"apis":[{"path":"/path","duration":7890},{"path":"/path","duration":6890},{"path":"/path","duration":5890}]}'
print(json.loads(apis))
apis_json = json.loads(apis)
# 一個個遍歷
api_duration = []
for api in apis_json["apis"]:
duration = api["duration"]
if int(duration) > 7000:
print(str(duration))
api_duration.append(api["path"])
print(api_duration)
通過jsonpath獲得
#jsonpath 更簡單 api_duration2 = jsonpath(apis_json, "$.apis[?(@.duration>7000)].path") print(api_duration2)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
python轉(zhuǎn)換wrf輸出的數(shù)據(jù)為網(wǎng)頁可視化json格式
這篇文章主要介紹了python轉(zhuǎn)換wrf輸出的數(shù)據(jù)為網(wǎng)頁可視化json格式,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下2022-09-09
Python中內(nèi)置數(shù)據(jù)類型list,tuple,dict,set的區(qū)別和用法
這篇文章主要給大家介紹了Python中內(nèi)置數(shù)據(jù)類型list,tuple,dict,set的區(qū)別和用法,都是非?;A的知識,十分的細致全面,有需要的小伙伴可以參考下。2015-12-12
Python將CSV文件轉(zhuǎn)化為HTML文件的操作方法
很多朋友問小編Python如何將CSV文件轉(zhuǎn)化為HTML文件,csv文件讀取怎么操作呢?帶著這些問題一起通過本文學習吧2021-06-06
FP-growth算法發(fā)現(xiàn)頻繁項集——構(gòu)建FP樹
常見的挖掘頻繁項集算法有兩類,一類是Apriori算法,另一類是FP-growth。Apriori通過不斷的構(gòu)造候選集、篩選候選集挖掘出頻繁項集,需要多次掃描原始數(shù)據(jù),當原始數(shù)據(jù)較大時,磁盤I/O次數(shù)太多,效率比較低下2021-06-06
Python寫的創(chuàng)建文件夾自定義函數(shù)mkdir()
這篇文章主要介紹了Python寫的創(chuàng)建文件夾自定義函數(shù)mkdir(),文件夾操作是編程中經(jīng)常需要的,mkdir函數(shù)更是經(jīng)典中的經(jīng)典,需要的朋友可以參考下2014-08-08

