解析python中的jsonpath 提取器

為什麼要用jsonpath

就跟為什麼要用xpath一樣,jsonpath的設計靈感來源於xpath。一個強大的json數據提取工具。讓用戶不用編寫腳本就可以提取到相應的json數據。

jsonpath的語法

jsonpath可以什麼這兩種模式來檢索數據:
以點為分隔
$.store.book[0].title
$.store.book[0,1] #可以取到第一個和第二個book值
$.store.book[*].title #可以取到所的的book值
以中括號為分隔
$['store']['book'][0]['title']
對於輸入.路徑,內中路徑將始終使用更通用的中括號模式。 (我猜是因為jsonpath在python中是dict,訪問方式剛好是用中括號)
還支持[start:end:step]模式
"$.store.book[0:3:2].title" #和python中的range步長計算是一致的
@符號表達式:即可以用來代表長度,也可以用來代表name。
$.store.book[(@.length-1)].title #取到最後一個book的title
$.store.book[?(@.price < 10)].title #取到價格小於10的書的title

jsonpath 解析

接下來講一個非常強大並且方便的 jsonpath 專門用於 json 解析,解決路徑深的老大難問題!
先安裝依賴包

pip install jsonpath

學習jsonpath 不得不提到xpath,這兩者之間的語法是差不多的

Xpath JSONPath 描述
/ $ 跟節點
. @ 現行節點
/ . or [] 取子節點
.. n/a 取父節點 JsonPath不支持
// .. 相對節點 就是不管位置,選擇所有符合條件的條件
  • |* |匹配所有元素節點

[] |[] |迭代器標示(可以在裡面做簡單的迭代操作,如數組下標,根據內容選值等)
&#124 |[,] |支持迭代器中做多選
[] |?() |支持過濾操作
n/a |() |支持表達式計算
() |n/a |分組,JsonPath不支持

使用示例

$是查找的根節點,傳參數是python的dict 類型,當查找到的時候返回一個list結果,查找失敗的時候返回 False.

import jsonpath
result = {
    "code": 0,
    "data": [
        {
            "age": 20,
            "create_time": "2021-09-15",
            "id": 1,
            "mail": "[email protected]",
            "name": "yoyo",
            "sex": "M"
        },
        {
            "age": 21,
            "create_time": "2021-09-16",
            "id": 2,
            "mail": "[email protected]",
            "name": "yoyo111",
            "sex": "M"
        }
    ],
    "msg": "success!"
}
msg = jsonpath.jsonpath(result, '$.msg')
print(msg)   # 輸出結果 ['success!']
names = jsonpath.jsonpath(result, '$..name')
print(names)   # 輸出結果 ['yoyo', 'yoyo111']
no = jsonpath.jsonpath(result, '$..yoyo')
print(no)   # 找不到是結果是 False

這樣就可以不用管層級結構也能取值瞭。

到此這篇關於python的jsonpath 提取器的文章就介紹到這瞭,更多相關python jsonpath 提取器內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: