<kbd id="afajh"><form id="afajh"></form></kbd>
<strong id="afajh"><dl id="afajh"></dl></strong>
    <del id="afajh"><form id="afajh"></form></del>
        1. <th id="afajh"><progress id="afajh"></progress></th>
          <b id="afajh"><abbr id="afajh"></abbr></b>
          <th id="afajh"><progress id="afajh"></progress></th>

          終結(jié) Python 原生字典?這個庫要逆天改命了

          共 4717字,需瀏覽 10分鐘

           ·

          2021-05-29 07:38


          作者 | 寫代碼的明哥
          來源 | Python編程時光


          大家好,我是豬哥,今天來聊一聊與字典相關的話題。

          字典是 Python 中基礎的數(shù)據(jù)結(jié)構(gòu)之一,字典的使用,可以說是非常的簡單粗暴,但即便是這樣一個與世無爭的數(shù)據(jù)結(jié)構(gòu),仍然有很多人 "看不慣它" 。
          也許你并不覺得,但我相信,你看了這篇文章后,一定會和我一樣,對原生字典開始有了偏見。
          我舉個簡單的例子吧
          當你想訪問字典中的某個 key 時,你需要使用字典特定的訪問方式,而這種方式需要你鍵入 一對中括號 還有 一對引號
          >>> profile = dict(name="iswbm")
          >>> profile
          {'name''iswbm'}
          >>> profile["name"]
          'iswbm'
          是不是開始覺得忍無可忍了?
          如果可以像調(diào)用對象屬性一樣使用 . 去訪問 key 就好了,可以省去很多多余的鍵盤擊入,就像這樣子
          >>> profile.name
          'iswbm'
          是的,今天這篇文章就是跟大家分享一種可以直接使用 . 訪問和操作字典的一個黑魔法庫 -- munch。

          1. 安裝方法

          使用如下命令進行安裝
          $ python -m pip install munch

          2. 簡單示例

          munch 有一個 Munch 類,它繼承自原生字典,使用 isinstance 可以驗證
          >>> from munch import Munch
          >>> profile = Munch()
          >>> isinstance(profile, dict)
          True
          >>>
          并實現(xiàn)了點式賦值與訪問,profile.nameprofile['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})
          >>>
          >>> del profile["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. 設置返回默認值

          當訪問一個字典中不存在的 key 時,會報 KeyError 的錯誤
          >>> profile = {}
          >>> profile["name"]
          Traceback (most recent call last):
            File "<stdin>", line 1in <module>
          KeyError: 'name'
          對于這種情況,通常我們會使用 get 來規(guī)避
          >>> profile = {}
          >>> profile.get("name""undefined")
          'undefined'
          當然你在 munch 中仍然可以這么用,不過還有一種更好的方法:使用 DefaultMunch,它會在你訪問不存在的 key 時,給你返回一個設定好的默認值
          >>> from munch import DefaultMunch
          >>> profile = DefaultMunch("undefined", {"name""iswbm"})
          >>> profile
          DefaultMunch('undefined', {'name''iswbm'})
          >>> profile.age
          'undefined'
          >>> profile
          DefaultMunch('undefined', {'name''iswbm'})

          5. 工廠函數(shù)自動創(chuàng)建key

          上面使用 DefaultMunch 僅當你訪問不存在的 key 是返回一個默認值,但這個行為并不會修改原 munch 對象的任何內(nèi)容。
          若你想訪問不存在的 key 時,自動觸發(fā)給原 munch 中新增你想要訪問的 key ,并為其設置一個默認值,可以試一下 DefaultFactoryMunch 傳入一個工廠函數(shù)。
          >>> from munch import DefaultFactoryMunch
          >>> 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
          >>> 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.Munch\nbar: 100\nfoo: !munch.Munch\n  lol: 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


          以上就是關于 munch 的使用全解,替換原生字典絕無問題,munch 的進一步封裝使得數(shù)據(jù)的訪問及操作更得更加 Pythonic 了,希望有一天這個特性能夠體現(xiàn)在原生的字典上。
          瀏覽 27
          點贊
          評論
          收藏
          分享

          手機掃一掃分享

          分享
          舉報
          評論
          圖片
          表情
          推薦
          點贊
          評論
          收藏
          分享

          手機掃一掃分享

          分享
          舉報
          <kbd id="afajh"><form id="afajh"></form></kbd>
          <strong id="afajh"><dl id="afajh"></dl></strong>
            <del id="afajh"><form id="afajh"></form></del>
                1. <th id="afajh"><progress id="afajh"></progress></th>
                  <b id="afajh"><abbr id="afajh"></abbr></b>
                  <th id="afajh"><progress id="afajh"></progress></th>
                  aaaaaa免费| 俺也去网址 | 在线视频这里只有精品6 | 午夜精产品一区二区在线观看 | 日本三级电影片一区二区 |