Python利用jmespath模塊進(jìn)行json數(shù)據(jù)處理
jmespath是python的第三方模塊,是需要額外安裝的。它在python原有的json數(shù)據(jù)處理上
做出了很大的貢獻(xiàn),至于效果接下來試試就知道了有多方便。
話不多說,我們直接進(jìn)入正題…
既然是第三方的庫,那肯定是要安裝的。通過pip的方式先將jmespath庫安裝好…
pip install jmespath
將安裝好的模塊導(dǎo)入到代碼塊中…
import jmespath as jp
jmespath中有一個很重要、很方便的函數(shù)那就是search,不管你的json數(shù)據(jù)有多么變態(tài),它都能給你找到。寫出這個框架的大佬也是費心了…
我先準(zhǔn)備了一個最簡單的json數(shù)據(jù)結(jié)構(gòu)的數(shù)據(jù),數(shù)據(jù)層級為1。
json_data1 = {"name": "Python 集中營", "age": "10年"} res = jp.search("name", json_data1) print(res) # Python 集中營
如果是多級的json數(shù)據(jù),可以使用key1.key2.key3的方式來獲取value值。
json_data2 = {"names": {"name": "Python 集中營", "age": "5年"}} res = jp.search("names.name", json_data2) print(res) # Python 集中營
既然是針對json數(shù)據(jù)的處理,那肯定也是支持?jǐn)?shù)組形式的查找的。對于json數(shù)據(jù)的數(shù)組形式的查找,主要是通過數(shù)組下標(biāo)的方式來獲取數(shù)據(jù)value值的。
json_data3 = ['Python 集中營', 'Sir.wang'] res = jp.search("[0]", json_data3) print(res) # Python 集中營
若是數(shù)組和字典的形式結(jié)合組成的json數(shù)據(jù),也可以組合使用查找方式。比如:有如下的json數(shù)據(jù)…
json_data4 = { "key1": {"key1_1": "value1_1"}, "key2": {"key2_1": ["a", "b", "c"]} }
面對稍微復(fù)雜一點的json數(shù)據(jù)可以先定義好表達(dá)式的字符串,最后再使用search函數(shù)進(jìn)行數(shù)據(jù)查找。比如:需要在json數(shù)據(jù)中找到如下的數(shù)組…
# ["a", "b", "c"] exp = "key2.key2_1[0]" res = jp.search(exp, json_data4) print("數(shù)組中的數(shù)值:", res) # 數(shù)組中的數(shù)值:a
那么,如何在json數(shù)據(jù)中使用切片的方式來找到需要的json數(shù)據(jù),當(dāng)然也是支持的…
json_data5 = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9] exp = "[0:7]" res = jp.search(exp, json_data5) print("切片數(shù)據(jù)結(jié)果", res) # 切片數(shù)據(jù)結(jié)果 [0, 1, 2, 3, 4, 5, 6]
還有一種查找方式,是通過*符號通配符的方式,主要是用在外層數(shù)據(jù)為數(shù)組的json數(shù)據(jù)中,比如有如下的數(shù)據(jù)…
json_data6 = { "data": [ {"name": "Python 集中營", "age": "5年"}, {"name": "Sir.wang", "age": "28"}, {"dr": "nrg"} ] }
這種數(shù)據(jù)形式的話,表達(dá)式可以這樣寫。先找到data作為鍵,這個時候是用data[*]就可以找到data下面的所有數(shù)據(jù),在通過下一個層級的鍵進(jìn)行匹配。
exp = "data[*].name" res = jp.search(exp,json_data6) print(res) # ['Python 集中營', 'Sir.wang']
若是想匹配到的鍵是dr,則將exp表達(dá)式修改成下面這樣就可以找到了…
exp = "data[*].dr" # 查找的結(jié)果則是下面這樣的... # ['nrg']
到此這篇關(guān)于Python利用jmespath模塊進(jìn)行json數(shù)據(jù)處理的文章就介紹到這了,更多相關(guān)Python json數(shù)據(jù)處理內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Python中的JMESPath庫示例詳解
- go語言搬磚之go jmespath實現(xiàn)查詢json數(shù)據(jù)
- 全面掌握Python?JSON庫函數(shù)與方法學(xué)會JSON數(shù)據(jù)處理
- Python中的JSON?Pickle?Shelve模塊特性與區(qū)別實例探究
- Python與Node.js之間實現(xiàn)通信的JSON數(shù)據(jù)接收發(fā)送
- python Aligo庫設(shè)置json路徑使用詳解
- Python文件操作JSON CSV TSV Excel和Pickle文件序列化
- Python?JMESPath庫輕松操作JSON進(jìn)行數(shù)據(jù)查詢方法實例
相關(guān)文章
pycharm2020上部署配置AutoGPT4.0(保姆級教程)
本文主要介紹了pycharm2020上部署配置AutoGPT4.0,文中通過圖文介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-06-06python檢測文件夾變化,并拷貝有更新的文件到對應(yīng)目錄的方法
今天小編就為大家分享一篇python檢測文件夾變化,并拷貝有更新的文件到對應(yīng)目錄的方法。具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-10-10在服務(wù)器上安裝python3.8.2環(huán)境的教程詳解
這篇文章主要介紹了在服務(wù)器上安裝python3.8.2環(huán)境的教程詳解,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-04-04Pycharm配置遠(yuǎn)程SSH服務(wù)器實現(xiàn)(切換不同虛擬環(huán)境)
本文主要介紹了Pycharm配置遠(yuǎn)程SSH服務(wù)器實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-02-02