python munch庫的使用解析
字典是 Python 中基礎(chǔ)的數(shù)據(jù)結(jié)構(gòu)之一,字典的使用,可以說是非常的簡單粗暴,但即便是這樣一個(gè)與世無爭的數(shù)據(jù)結(jié)構(gòu),仍然有很多人 '看不慣它' 。也許你并不覺得,但我相信,你看了這篇文章后,一定會(huì)和我一樣,對(duì)原生字典開始有了偏見。我舉個(gè)簡單的例子吧當(dāng)你想訪問字典中的某個(gè) key 時(shí),你需要使用字典特定的訪問方式,而這種方式需要你鍵入 一對(duì)中括號(hào) 還有 一對(duì)引號(hào)
>>> profile = dict(name='iswbm')>>> profile{’name’: ’iswbm’}>>> profile['name']’iswbm’
是不是開始覺得忍無可忍了?如果可以像調(diào)用對(duì)象屬性一樣使用 . 去訪問 key 就好了,可以省去很多多余的鍵盤擊入,就像這樣子
>>> profile.name’iswbm’
是的,今天這篇文章就是跟大家分享一種可以直接使用 . 訪問和操作字典的一個(gè)黑魔法庫 -- munch。
1. 安裝方法使用如下命令進(jìn)行安裝
$ python -m pip install munch2. 簡單示例
munch 有一個(gè) Munch 類,它繼承自原生字典,使用 isinstance 可以驗(yàn)證
>>> from munch import Munch>>> profile = Munch()>>> isinstance(profile, dict)True>>>
并實(shí)現(xiàn)了點(diǎn)式賦值與訪問,profile.name 與 profile[’name’] 是等價(jià)的
>>> profile.name = 'iswbm'>>> profile.age = 18>>> profileMunch({’name’: ’iswbm’, ’age’: 18})>>>>>> profile.name’iswbm’>>> profile['name']’iswbm’3. 兼容字典的所有操作
本身 Munch 繼承自 dict,dict 的操作也同樣適用于 Munch 對(duì)象,不妨再來驗(yàn)證下首先是:增刪改查
# 新增元素>>> profile['gender'] = 'male'>>> profileMunch({’name’: ’iswbm’, ’age’: 18, ’gender’: ’male’})# 修改元素>>> profile['gender'] = 'female'>>> profileMunch({’name’: ’iswbm’, ’age’: 18, ’gender’: ’female’})# 刪除元素>>> profile.pop('gender')’female’>>> profileMunch({’name’: ’iswbm’, ’age’: 18})>>>>>> del profile['age']>>> profileMunch({’name’: ’iswbm’})
再者是:一些常用方法
>>> profile.keys()dict_keys([’name’])>>>>>> profile.values()dict_values([’iswbm’])>>>>>> profile.get(’name’)’iswbm’>>> profile.setdefault(’gender’, ’male’)’male’>>> profileMunch({’name’: ’iswbm’, ’gender’: ’male’})4. 設(shè)置返回默認(rèn)值
當(dāng)訪問一個(gè)字典中不存在的 key 時(shí),會(huì)報(bào) KeyError 的錯(cuò)誤
>>> profile = {}>>> profile['name']Traceback (most recent call last): File '<stdin>', line 1, in <module>KeyError: ’name’
對(duì)于這種情況,通常我們會(huì)使用 get 來規(guī)避
>>> profile = {}>>> profile.get('name', 'undefined')’undefined’
當(dāng)然你在 munch 中仍然可以這么用,不過還有一種更好的方法:使用 DefaultMunch,它會(huì)在你訪問不存在的 key 時(shí),給你返回一個(gè)設(shè)定好的默認(rèn)值
>>> from munch import DefaultMunch>>> profile = DefaultMunch('undefined', {'name': 'iswbm'})>>> profileDefaultMunch(’undefined’, {’name’: ’iswbm’})>>> profile.age’undefined’>>> profileDefaultMunch(’undefined’, {’name’: ’iswbm’})5. 工廠函數(shù)自動(dòng)創(chuàng)建key
上面使用 DefaultMunch 僅當(dāng)你訪問不存在的 key 是返回一個(gè)默認(rèn)值,但這個(gè)行為并不會(huì)修改原 munch 對(duì)象的任何內(nèi)容。若你想訪問不存在的 key 時(shí),自動(dòng)觸發(fā)給原 munch 中新增你想要訪問的 key ,并為其設(shè)置一個(gè)默認(rèn)值,可以試一下 DefaultFactoryMunch 傳入一個(gè)工廠函數(shù)。
>>> from munch import DefaultFactoryMunch>>> profile = DefaultFactoryMunch(list, name=’iswbm’)>>> profileDefaultFactoryMunch(list, {’name’: ’iswbm’})>>>>>> profile.brothers[]>>> profileDefaultFactoryMunch(list, {’name’: ’iswbm’, ’brothers’: []})6. 序列化的支持
Munch 支持序列化為 JSON 或者 YAML 格式的字符串對(duì)象轉(zhuǎn)換成 JSON
>>> from munch import Munch>>> munch_obj = Munch(foo=Munch(lol=True), bar=100, msg=’hello’)>>>>>> import json>>> json.dumps(munch_obj)’{'foo': {'lol': true}, 'bar': 100, 'msg': 'hello'}’
轉(zhuǎn)換成 YAML
>>> from munch import Munch>>> munch_obj = Munch(foo=Munch(lol=True), bar=100, msg=’hello’)>>> import yaml>>> yaml.dump(munch_obj)’!munch.Munchnbar: 100nfoo: !munch.Munchn lol: truenmsg: hellon’>>>>>> print(yaml.dump(munch_obj))!munch.Munchbar: 100foo: !munch.Munch lol: truemsg: hello>>>
建議使用 safe_dump 去掉 !munch.Munch
>>> print(yaml.safe_dump(munch_obj))bar: 100foo: lol: truemsg: hello
以上就是關(guān)于 munch 的使用全解,替換原生字典絕無問題,munch 的進(jìn)一步封裝使得數(shù)據(jù)的訪問及操作更得更加 Pythonic 了,希望有一天這個(gè)特性能夠體現(xiàn)在原生的字典上。
到此這篇關(guān)于python munch庫的使用解析的文章就介紹到這了,更多相關(guān)python munch庫的使用內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. python使用ctypes庫調(diào)用DLL動(dòng)態(tài)鏈接庫2. 詳解java中static關(guān)鍵詞的作用3. Python實(shí)現(xiàn)迪杰斯特拉算法過程解析4. Java14發(fā)布了,再也不怕NullPointerException了5. Python如何進(jìn)行時(shí)間處理6. Java面向?qū)ο蠡A(chǔ)教學(xué)(三)7. python裝飾器三種裝飾模式的簡單分析8. 詳解Python模塊化編程與裝飾器9. 關(guān)于Java下奇怪的Base64詳解10. python gstreamer實(shí)現(xiàn)視頻快進(jìn)/快退/循環(huán)播放功能
