python munch庫的使用解析
字典是 Python 中基礎(chǔ)的數(shù)據(jù)結(jié)構(gòu)之一,字典的使用,可以說是非常的簡單粗暴,但即便是這樣一個與世無爭的數(shù)據(jù)結(jié)構(gòu),仍然有很多人 "看不慣它" 。
也許你并不覺得,但我相信,你看了這篇文章后,一定會和我一樣,對原生字典開始有了偏見。
我舉個簡單的例子吧
當(dāng)你想訪問字典中的某個 key 時,你需要使用字典特定的訪問方式,而這種方式需要你鍵入 一對中括號 還有 一對引號
>>>profile=dict(name="iswbm") >>>profile {'name':'iswbm'} >>>profile["name"] 'iswbm'
是不是開始覺得忍無可忍了?
如果可以像調(diào)用對象屬性一樣使用 . 去訪問 key 就好了,可以省去很多多余的鍵盤擊入,就像這樣子
>>>profile.name 'iswbm'
是的,今天這篇文章就是跟大家分享一種可以直接使用 . 訪問和操作字典的一個黑魔法庫 -- munch。
1. 安裝方法
使用如下命令進(jìn)行安裝
$python-mpipinstallmunch
2. 簡單示例
munch 有一個 Munch 類,它繼承自原生字典,使用 isinstance 可以驗證
>>>frommunchimportMunch >>>profile=Munch() >>>isinstance(profile,dict) True >>>
并實(shí)現(xiàn)了點(diǎn)式賦值與訪問,profile.name 與 profile['name'] 是等價的
>>>profile.name="iswbm" >>>profile.age=18 >>>profile Munch({'name':'iswbm','age':18}) >>> >>>profile.name 'iswbm' >>>profile["name"] 'iswbm'
3. 兼容字典的所有操作
本身 Munch 繼承自 dict,dict 的操作也同樣適用于 Munch 對象,不妨再來驗證下
首先是:增刪改查
#新增元素 >>>profile["gender"]="male" >>>profile Munch({'name':'iswbm','age':18,'gender':'male'}) #修改元素 >>>profile["gender"]="female" >>>profile Munch({'name':'iswbm','age':18,'gender':'female'}) #刪除元素 >>>profile.pop("gender") 'female' >>>profile Munch({'name':'iswbm','age':18}) >>> >>>delprofile["age"] >>>profile Munch({'name':'iswbm'})
再者是:一些常用方法
>>>profile.keys() dict_keys(['name']) >>> >>>profile.values() dict_values(['iswbm']) >>> >>>profile.get('name') 'iswbm' >>>profile.setdefault('gender','male') 'male' >>>profile Munch({'name':'iswbm','gender':'male'})
4. 設(shè)置返回默認(rèn)值
當(dāng)訪問一個字典中不存在的 key 時,會報 KeyError 的錯誤
>>>profile={} >>>profile["name"] Traceback(mostrecentcalllast): File"<stdin>",line1,in<module> KeyError:'name'
對于這種情況,通常我們會使用 get 來規(guī)避
>>>profile={} >>>profile.get("name","undefined") 'undefined'
當(dāng)然你在 munch 中仍然可以這么用,不過還有一種更好的方法:使用 DefaultMunch,它會在你訪問不存在的 key 時,給你返回一個設(shè)定好的默認(rèn)值
>>>frommunchimportDefaultMunch >>>profile=DefaultMunch("undefined",{"name":"iswbm"}) >>>profile DefaultMunch('undefined',{'name':'iswbm'}) >>>profile.age 'undefined' >>>profile DefaultMunch('undefined',{'name':'iswbm'})
5. 工廠函數(shù)自動創(chuàng)建key
上面使用 DefaultMunch 僅當(dāng)你訪問不存在的 key 是返回一個默認(rèn)值,但這個行為并不會修改原 munch 對象的任何內(nèi)容。
若你想訪問不存在的 key 時,自動觸發(fā)給原 munch 中新增你想要訪問的 key ,并為其設(shè)置一個默認(rèn)值,可以試一下 DefaultFactoryMunch 傳入一個工廠函數(shù)。
>>>frommunchimportDefaultFactoryMunch >>>profile=DefaultFactoryMunch(list,name='iswbm') >>>profile DefaultFactoryMunch(list,{'name':'iswbm'}) >>> >>>profile.brothers [] >>>profile DefaultFactoryMunch(list,{'name':'iswbm','brothers':[]})
6. 序列化的支持
Munch 支持序列化為 JSON 或者 YAML 格式的字符串對象
轉(zhuǎn)換成 JSON
>>>frommunchimportMunch >>>munch_obj=Munch(foo=Munch(lol=True),bar=100,msg='hello') >>> >>>importjson >>>json.dumps(munch_obj) '{"foo":{"lol":true},"bar":100,"msg":"hello"}'
轉(zhuǎn)換成 YAML
>>>frommunchimportMunch >>>munch_obj=Munch(foo=Munch(lol=True),bar=100,msg='hello') >>>importyaml >>>yaml.dump(munch_obj) '!munch.Munch\nbar:100\nfoo:!munch.Munch\nlol:true\nmsg:hello\n' >>> >>>print(yaml.dump(munch_obj)) !munch.Munch bar:100 foo:!munch.Munch lol:true msg:hello >>>
建議使用 safe_dump 去掉 !munch.Munch
>>>print(yaml.safe_dump(munch_obj)) bar:100 foo: lol:true msg:hello
以上就是關(guān)于 munch 的使用全解,替換原生字典絕無問題,munch 的進(jìn)一步封裝使得數(shù)據(jù)的訪問及操作更得更加 Pythonic 了,希望有一天這個特性能夠體現(xiàn)在原生的字典上。
到此這篇關(guān)于python munch庫的使用解析的文章就介紹到這了,更多相關(guān)python munch庫的使用內(nèi)容請搜索本站以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持本站!
版權(quán)聲明:本站文章來源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請保持原文完整并注明來源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非www.sddonglingsh.com所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學(xué)習(xí)參考,不代表本站立場,如有內(nèi)容涉嫌侵權(quán),請聯(lián)系alex-e#qq.com處理。