Python json解析庫jsonpath原理及使用示例
jsonpath
jsonpath 用于多層嵌套 json格式的 解析。
pip install jsonpath
JsonPath 描述 $ 根節(jié)點 @ 現(xiàn)行節(jié)點 .or[] 取子節(jié)點 n/a 取父節(jié)點,jsonpath為支持 .. 就是不管位置,選擇所有復(fù)合條件的條件 * 匹配所有元素節(jié)點 n/a 根據(jù)屬性訪問,json不支持,因為json是個key-value遞歸結(jié)構(gòu),不需要數(shù)屬性訪問 [] 迭代器標(biāo)示(可以在里邊做簡單的迭代操作,如數(shù)組下標(biāo),根據(jù)內(nèi)容選值等) [,] 支持迭代器中做多選 ?() 支持過濾操作 () 支持表達式計算 n/a 分組,JsonPath不支持
jsonpath使用示例
book_dict = { '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 Result $.store.book[*].author store中的所有的book作者 $…author 所有的作者 $.store.* store下的所有元素 $.store…price store中的所有價錢 $…book[2] 第三本書 $…book[(@.length-1)] 最后一本書 $…book[0,1] 取前兩本書 $…book[?(@.isbn)] 獲取有jsbn的所有數(shù) $…book[?(@.price<10)] 獲取價格大于10 $…* 匹配所有數(shù)據(jù)
使用示例
$ 是查找的根節(jié)點,傳參數(shù)是python的dict 類型,當(dāng)查找到的時候返回一個list結(jié)果,查找失敗的時候返回 False.
import jsonpathresult = { 'code': 0, 'data': [ { 'age': 20, 'create_time': '2019-09-15', 'id': 1, 'mail': '[email protected]', 'name': 'yoyo', 'sex': 'M' }, { 'age': 21, 'create_time': '2019-09-16', 'id': 2, 'mail': '[email protected]', 'name': 'yoyo111', 'sex': 'M' } ], 'msg': 'success!'}msg = jsonpath.jsonpath(result, ’$.msg’)print(msg) # 輸出結(jié)果 [’success!’]names = jsonpath.jsonpath(result, ’$..name’)print(names) # 輸出結(jié)果 [’yoyo’, ’yoyo111’]no = jsonpath.jsonpath(result, ’$..yoyo’)print(no) # 找不到是結(jié)果是 False
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. .NET SkiaSharp 生成二維碼驗證碼及指定區(qū)域截取方法實現(xiàn)2. css代碼優(yōu)化的12個技巧3. HTTP協(xié)議常用的請求頭和響應(yīng)頭響應(yīng)詳解說明(學(xué)習(xí))4. idea設(shè)置提示不區(qū)分大小寫的方法5. CentOS郵件服務(wù)器搭建系列—— POP / IMAP 服務(wù)器的構(gòu)建( Dovecot )6. ASP.NET MVC通過勾選checkbox更改select的內(nèi)容7. Django使用HTTP協(xié)議向服務(wù)器傳參方式小結(jié)8. IntelliJ IDEA創(chuàng)建web項目的方法9. django創(chuàng)建css文件夾的具體方法10. 原生JS實現(xiàn)記憶翻牌游戲
