python glom模塊的使用簡介
工欲善其事,必先利其器!我們想要更輕松更有效率地開發(fā),必須學(xué)會一些“高級”技能。前不久看到一位 Python 高僧的代碼,其中使用了一個短小精悍的模塊,我認(rèn)為還蠻有用的,今天分享給大家。
這個模塊就叫 glom ,是 Python 處理數(shù)據(jù)的一個小模塊,它具有如下特點:
- 嵌套結(jié)構(gòu)并基于路徑訪問
- 使用輕量級的Pythonic規(guī)范進(jìn)行聲明性數(shù)據(jù)轉(zhuǎn)換
- 可讀、有意義的錯誤信息
- 內(nèi)置數(shù)據(jù)探測和調(diào)試功能
看起來比較抽象,對不對?下面我們用實例來給大家演示一下。
安裝
作為 Python 內(nèi)置模塊,相信你一定知道怎么安裝:
pip3 install glom
幾秒鐘就搞定!
簡單使用
我們來看看最簡單的用法:
d = {"a": {"b": {"c": 1}}} print(glom(d, "a.b.c")) # 1
在這里,我們有一個嵌套三層的 json 結(jié)構(gòu),我們想獲取最里層的 c 對應(yīng)的值,正常的寫法應(yīng)該是:
print(d["a"]["b"]["c"])
如果到這里,我說 glom 比傳統(tǒng)方式好一些,因為你不用一層層地寫中括號和引號,你會不會嗤之以鼻?
好,我們再來看看下面的情況:
d = {"a": {"b": None}} print(d["a"]["b"]["c"])
遍歷到一個 None 對象,你會收到下面的錯誤:
Traceback (most recent call last): File "/Users/cxhuan/Documents/python_workspace/mypy/pmodules/pglom/glomstudy.py", line 10, in <module> print(d["a"]["b"]["c"]) TypeError: 'NoneType' object is not subscriptable
我們來看看 glom 的處理方式:
from glom import glom d = {"a": {"b": None}} print(glom(d, "a.b.c"))
同樣地,glom 不能把錯誤的輸出成對的,你會得到以下錯誤:
Traceback (most recent call last): File "/Users/cxhuan/Documents/python_workspace/mypy/pmodules/pglom/glomstudy.py", line 11, in <module> print(glom(d, "a.b.c")) File "/Library/Frameworks/Python.framework/Versions/3.7/lib/python3.7/site-packages/glom/core.py", line 2181, in glom raise err glom.core.PathAccessError: error raised while processing, details below. Target-spec trace (most recent last): - Target: {'a': {'b': None}} - Spec: 'a.b.c' glom.core.PathAccessError: could not access 'c', part 2 of Path('a', 'b', 'c'), got error: AttributeError("'NoneType' object has no attribute 'c'")
如果你仔細(xì)看報錯內(nèi)容,你就會發(fā)現(xiàn)這報錯內(nèi)容極其詳細(xì),一目了然,這對于找程序 bug 簡直是神器!
復(fù)雜用法
剛才簡單的例子,讓大家對 glom 有了直觀的認(rèn)識,接下來我們看看 glom 的 glom 方法的定義:
glom(target, spec, **kwargs)
我們看看參數(shù)的含義:
- target:目標(biāo)數(shù)據(jù),可以是dict、list或者其他任何對象
- spec:是我們希望輸出的內(nèi)容
下面我們來使用這個方法。
先看一個例子。我們有一個 dict ,想要獲取出 所有 name 的值,我們可以通過 glom 來實現(xiàn):
data = {"student": {"info": [{"name": "張三"}, {"name": "李四"}]}} info = glom(data, ("student.info", ["name"])) print(info) # ['張三', '李四']
如果用傳統(tǒng)方式的話,我們可能會需要遍歷才能獲取到,但是使用 glom ,我們只需要一行代碼就可以了,輸出是一個數(shù)組。
如果你不想輸出數(shù)組,而是想要一個 dict 的話,那也是很簡單的:
info = glom(data, {"info": ("student.info", ["name"])}) print(info) # {'info': ['張三', '李四']
我們只需要將原來的數(shù)組賦值給一個字典來接收就好了。
搞定麻煩需求
假如我現(xiàn)在有兩組數(shù)據(jù),我要取出 name 的值:
data_1 = {"school": {"student": [{"name": "張三"}, {"name": "李四"}]}} data_2 = {"school": {"teacher": [{"name": "王老師"}, {"name": "趙老師"}]}} spec_1 = {"name": ("school.student", ["name"])} spec_2 = {"name": ("school.teacher", ["name"])} print(glom(data_1, spec_1)) # {'name': ['張三', '李四']} print(glom(data_2, spec_2)) # {'name': ['王老師', '趙老師']}
我們通常是這么寫,對嗎?假如我們有好多組數(shù)據(jù),每組都是類似的取法呢?這時候我們就會想辦法避免一個個重復(fù)寫 N 行參數(shù)了,我們可以使用 Coalesce 方法:
data_1 = {"school": {"student": [{"name": "張三"}, {"name": "李四"}]}} data_2 = {"school": {"teacher": [{"name": "王老師"}, {"name": "趙老師"}]}} spec = {"name": (Coalesce("school.student", "school.teacher"), ["name"])} print(glom(data_1, spec)) # {'name': ['張三', '李四']} print(glom(data_2, spec)) # {'name': ['王老師', '趙老師']}
我們可以用 Coalesce 把多個需求聚合起來,然后針對同一個 spec 來取值就行了。
下面再來一個大殺器——取值計算。glom 還可以對取值進(jìn)行簡單計算,我們來看例子:
data = {"school": {"student": [{"name": "張三", "age": 8}, {"name": "李四", "age": 10}]}} spec = {"sum_age": ("school.student", ["age"], sum)} print(glom(data, spec)) # {'sum_age': 18}
總結(jié)
介紹了這么多,大家應(yīng)該知道 glom 的厲害之處了吧,據(jù)說很多大佬都喜歡使用呢。其實它還有很多其他的實用功能有待大家去發(fā)掘,這里就不一一介紹了。
以上就是python glom模塊的使用簡介的詳細(xì)內(nèi)容,更多關(guān)于python glom模塊的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Python嵌套函數(shù),作用域與偏函數(shù)用法實例分析
這篇文章主要介紹了Python嵌套函數(shù),作用域與偏函數(shù)用法,結(jié)合實例形式分析了Python嵌套函數(shù),作用域與偏函數(shù)的功能、定義與相關(guān)使用方法,需要的朋友可以參考下2019-12-12python項目報錯:bs4.FeatureNotFound:?Couldn‘t?find?a?tree?bu
這篇文章主要給大家介紹了python項目報錯:bs4.FeatureNotFound:?Couldn‘t?find?a?tree?builder?with?the?features?you?requests的解決方式,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下2022-09-09Python爬蟲通過替換http request header來欺騙瀏覽器實現(xiàn)登錄功能
這篇文章主要介紹了Python爬蟲通過替換http request header來欺騙瀏覽器實現(xiàn)登錄功能,需要的朋友可以參考下2018-01-01基于Django的Admin后臺實現(xiàn)定制簡單監(jiān)控頁
Django自帶的后臺管理是Django明顯特色之一,可以讓我們快速便捷管理數(shù)據(jù)。后臺管理可以在各個app的admin.py文件中進(jìn)行控制。本文將主要介紹如何利用Admin后臺實現(xiàn)監(jiān)控頁的定制,快來和小編一起學(xué)習(xí)一下吧2021-12-12python模塊shutil函數(shù)應(yīng)用示例詳解教程
這篇文章主要為大家介紹了python模塊中shutil函數(shù)的應(yīng)用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2021-10-10pandas讀取excel統(tǒng)計空值數(shù)量錯誤的解決方法
pd.read_excel()讀取excel數(shù)據(jù)后,用pd.isnull().sum()統(tǒng)計空值數(shù)量不對,本文主要介紹了pandas讀取excel統(tǒng)計空值數(shù)量錯誤的解決方法,感興趣的可以了解一下2024-04-04pandas中concatenate和combine_first的用法詳解
本文主要介紹了pandas中concatenate和combine_first的用法詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-01-01Visual Studio code 配置Python開發(fā)環(huán)境
這篇文章主要介紹了Visual Studio code 配置Python開發(fā)環(huán)境,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09