在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

Python模塊Addict的安裝與使用

python爬蟲知識分享 ? 來源:python爬蟲知識分享 ? 作者:python爬蟲知識分享 ? 2022-06-21 16:14 ? 次閱讀

Addit 是一個Python模塊,除了提供標準的字典語法外,Addit 生成的字典的值既可以使用屬性來獲取,也可以使用屬性進行設置。

這意味著你不用再寫這樣的字典了:

body = {
    'query': {
        'filtered': {
            'query': {
                'match': {'description': 'addictive'}
            },
            'filter': {
                'term': {'created_by': 'Mats'}
            }
        }
    }
}

相反,你只需編寫以下三行代碼就能完成目的:

body = Dict()
body.query.filtered.query.match.description = 'addictive'
body.query.filtered.filter.term.created_by = 'Mats'

1.安裝

你可以通過pip安裝:

pip installaddict

或通過conda

conda installaddict -c conda-forge

Addit 在Python2.7+和Python3上都可以運行。

2.用法

Addict 繼承自字典,但在訪問和設置其值方面更加靈活。使用 Addict 的字典是一種樂趣!
設置嵌套詞典的項是極其舒服的:

>>> from addict import Dict
>>> mapping = Dict()
>>> mapping.a.b.c.d.e = 2
>>> mapping
{'a': {'b': {'c': {'d': {'e': 2}}}}}

如果Dict是用任何可迭代值實例化的,它將遍歷并克隆這些值,然后寫入到對應的屬性及值中,比如:

>>> mapping = {'a': [{'b': 3}, {'b': 3}]}
>>> dictionary = Dict(mapping)
>>> dictionary.a[0].b
3

mapping['a']不再與dictionary['a']相同。

>>> mapping['a'] is dictionary['a']
False

當然,此特點僅限于構造函數,而不是在使用屬性或設置值時:

>>> a = Dict()
>>> b = [1, 2, 3]
>>> a.b = b
>>> a.b is b
True

3.要牢記的事情

記住,int不是有效的屬性名,因此必須使用 get/setitem 語法 設置/獲取 非字符串的 dict 鍵:

>>> mapping = Dict()
>>> mapping.keys = 2
Traceback (most recent call last):
File "", line 1, in 
 File "addict/addict.py", line 53, in __setattr__
 raise AttributeError("'Dict' object attribute '%s' is read-only" % name)
AttributeError: 'Dict' object attribute 'keys' is read-only

不過,你可以隨意混合使用這兩種語法:

>>> addicted.a.b['c'].d.e
2

4.屬性,如鍵、item等

Addit 不會讓你覆蓋dict的屬性,因此以下操作將不起作用:

>>> mapping = Dict()
>>> mapping.keys = 2
Traceback (most recent call last):
File "", line 1, in 
 File "addict/addict.py", line 53, in __setattr__
 raise AttributeError("'Dict' object attribute '%s' is read-only" % name)
AttributeError: 'Dict' object attribute 'keys' is read-only

不過,使用下面這種方式就可以:

>>> a = Dict()
>>> a['keys'] = 2
>>> a
{'keys': 2}
>>> a['keys']
2

5.默認值

對于不在字典中的鍵,Addit的行為如defaultdict(Dict),因此丟失的鍵返回一個空的Dict而不是拋出KeyError如果此行為不是所需的,則可以使用以下方式恢復拋出KeyError:

>>> class DictNoDefault(Dict):
>>>   def __missing__(self, key):
>>>     raise KeyError(key)

但請注意,這樣會失去速記賦值功能(addicted.a.b.c.d.e = 2)

6.轉化為普通字典

如果你覺得將 Addict 傳遞到其他函數或模塊并不安全,請使用to_dict()方法,它返回會把 Addict 轉化為普通字典。

>>> regular_dict = my_addict.to_dict()
>>> regular_dict.a = 2
Traceback (most recent call last):
File "", line 1, in 
 AttributeError: 'dict' object has no attribute 'a'

當您希望在幾行代碼中創建嵌套的字典,然后將其發送到不同的函數或模塊時,這非常適合:

body = Dict()
body.query.filtered.query.match.description = 'addictive'
body.query.filtered.filter.term.created_by = 'Mats'
third_party_module.search(query=body.to_dict())

7.計數

Dict輕松訪問和修改深度嵌套屬性的能力使其成為計數的理想選擇。使用Addict,你還可以容易允許按多個級別計數,內部使用的原理是collections.Counter

比如以下數據:

data = [
    {'born': 1980, 'gender': 'M', 'eyes': 'green'},
    {'born': 1980, 'gender': 'F', 'eyes': 'green'},
    {'born': 1980, 'gender': 'M', 'eyes': 'blue'},
    {'born': 1980, 'gender': 'M', 'eyes': 'green'},
    {'born': 1980, 'gender': 'M', 'eyes': 'green'},
    {'born': 1980, 'gender': 'F', 'eyes': 'blue'},
    {'born': 1981, 'gender': 'M', 'eyes': 'blue'},
    {'born': 1981, 'gender': 'F', 'eyes': 'green'},
    {'born': 1981, 'gender': 'M', 'eyes': 'blue'},
    {'born': 1981, 'gender': 'F', 'eyes': 'blue'},
    {'born': 1981, 'gender': 'M', 'eyes': 'green'},
    {'born': 1981, 'gender': 'F', 'eyes': 'blue'}
]

如果你想計算有多少人出生在born性別的gender使用eyes眼睛,你可以很容易地計算出這些信息:

counter = Dict()

for row in data:
    born = row['born']
    gender = row['gender']
    eyes = row['eyes']

    counter[born][gender][eyes] += 1 print(counter)

# 結果:{1980: {'M': {'blue': 1, 'green': 3}, 'F': {'blue': 1, 'green': 1}}, 1981: {'M': {'blue': 2, 'green': 1}, 'F': {'blue': 2, 'green': 1}}}

8.更新

普通字典的更新方式如下:

>>> d = {'a': {'b': 3}}
>>> d.update({'a': {'c': 4}})
>>> print(d)
{'a': {'c': 4}}

addict的更新方式如下,它會遞歸并實際更新嵌套的字典:

>>> D = Dict({'a': {'b': 3}})
>>> D.update({'a': {'c': 4}})
>>> print(D)
{'a': {'b': 3, 'c': 4}}

9.Addict 是怎么來的?

這個模塊完全是從用Python創建Elasticsearch查詢的繁瑣過程中發展而來的。每當你發現自己在寫了很復雜的字典邏輯時,只要記住你沒有必要這樣做,使用 Addict 就行。

審核編輯:湯梓紅

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 模塊
    +關注

    關注

    7

    文章

    2785

    瀏覽量

    49842
  • 代碼
    +關注

    關注

    30

    文章

    4891

    瀏覽量

    70351
  • python
    +關注

    關注

    56

    文章

    4825

    瀏覽量

    86355
收藏 人收藏

    評論

    相關推薦
    熱點推薦

    ?如何在虛擬環境中使用 Python,提升你的開發體驗~

    RaspberryPiOS預裝了Python,你需要使用其虛擬環境來安裝包。今天出版的最新一期《TheMagPi》雜志刊登了我們文檔負責人NateContino撰寫的一篇實用教程,幫助你入門
    的頭像 發表于 03-25 09:34 ?270次閱讀
    ?如何在虛擬環境中使用 <b class='flag-5'>Python</b>,提升你的開發體驗~

    運行OVModelForCausalLM Python模塊時出錯了,怎么解決?

    創建了一個自定義 Python* 代碼,類似于遵循 240-dolly-2-instruction 的 Jupyter 筆記本。 OVModelForCausalLM Python* 模塊運行時出錯。
    發表于 03-05 06:44

    使用Python實現xgboost教程

    使用Python實現XGBoost模型通常涉及以下幾個步驟:數據準備、模型訓練、模型評估和模型預測。以下是一個詳細的教程,指導你如何在Python中使用XGBoost。 1. 安裝XGBoost
    的頭像 發表于 01-19 11:21 ?1223次閱讀

    Flexus 云服務器 X:Python 安裝的極致便捷之旅

    前言 ????????Python 作為一種高級編程語言,因其簡潔易讀的語法和強大的庫支持,在數據科學、人工智能、Web 開發等領域得到了廣泛應用。然而,不同平臺上的安裝過程可能會有所不同,尤其是在
    的頭像 發表于 01-07 17:00 ?319次閱讀
    Flexus 云服務器 X:<b class='flag-5'>Python</b> <b class='flag-5'>安裝</b>的極致便捷之旅

    EMMC存儲模塊安裝與配置

    ,使得存儲模塊可以輕松集成到各種設備中。與傳統的SD卡相比,EMMC提供了更高的數據傳輸速率和更低的功耗。 安裝前的準備 在開始安裝EMMC存儲模塊之前,需要確保以下準備工作已經完成:
    的頭像 發表于 12-25 09:49 ?1962次閱讀

    Triton編譯器安裝步驟詳解

    :用于構建項目。 Python :用于運行 Triton 的 Python 綁定。 其他依賴 :根據您選擇的架構,可能需要額外的依賴。 2. 安裝依賴 對于 Linux: 打開終端并運行以下命令來
    的頭像 發表于 12-24 17:35 ?2245次閱讀

    使用Python進行串口通信的案例

    當然!以下是一個使用Python進行串口通信的簡單示例。這個示例展示了如何配置串口、發送數據以及接收數據。我們將使用 pyserial 庫,這是一個非常流行的用于串口通信的Python庫。 首先,你
    的頭像 發表于 11-22 09:11 ?1278次閱讀

    電腦是已經安裝python2.7,為什么打開GUI的script window時,一直提示未找到python2.7?

    電腦是已經安裝python2.7,為什么打開GUI的script window時,一直提示未找到python2.7?
    發表于 11-14 07:50

    LORA模塊安裝與配置指南

    以下是LoRa模塊安裝與配置指南: 一、安裝步驟 硬件連接 : 將LoRa模塊與主機(如PC或其他具有UART接口的設備)連接起來。通常,LoRa
    的頭像 發表于 10-31 17:37 ?4429次閱讀

    python寫驗證環境cocotb

    本文介紹了cocotb的安裝python tb文件的寫法、用xrun仿真cocotb的腳本等,我們來看看體驗如何。
    的頭像 發表于 07-24 09:38 ?970次閱讀
    用<b class='flag-5'>python</b>寫驗證環境cocotb

    如何實現Python復制文件操作

    Python 中有許多“開蓋即食”的模塊(比如 os,subprocess 和 shutil)以支持文件 I/O 操作。在這篇文章中,你將會看到一些用 Python 實現文件復制的特殊方法。下面我們開始學習這九種不同的方法來實現
    的頭像 發表于 07-18 14:53 ?733次閱讀

    網絡模塊安裝方法

    網絡模塊安裝方法主要包括以下幾個步驟,這些步驟將確保安裝的準確性和網絡模塊的穩定運行: 準備階段: 確定網絡設備的型號、規格和技術參數,確保所選的網絡
    的頭像 發表于 07-12 09:58 ?1536次閱讀

    python訓練出的模型怎么調用

    使用pickle模塊 pickle 是Python的一個內置模塊,用于序列化和反序列化Python對象結構。使用 pickle 可以方便地保存和加載模型。 import pickle
    的頭像 發表于 07-11 10:15 ?3260次閱讀

    用pycharm進行python爬蟲的步驟

    以下是使用PyCharm進行Python爬蟲的步驟: 安裝PyCharm和Python 首先,您需要安裝PyCharm和Python。PyC
    的頭像 發表于 07-11 10:11 ?1371次閱讀

    安裝依賴的Python軟件包時報錯如何解決?

    安裝依賴的 Python 軟件包,出現了如下錯誤,請問如何解決,謝謝! Command \"E:/msys32/mingw32/bin/python2.7.exe E:/msys32
    發表于 06-26 07:32
    主站蜘蛛池模板: 一级片免费在线观看视频 | 亚洲伊人久久综合影院2021 | 手机在线看片福利盒子 | 女人张开腿给男人桶爽免费 | 性欧美大战久久久久久久野外 | 久久久久久久久女黄 | 亚洲激情a| 亚洲一区二区免费视频 | 欧美资源在线观看 | 亚洲三区视频 | 午夜神马福利免费官方 | 一区二区免费 | 久久电影福利 | 欧美一级做一级做片性十三 | 四虎在线永久视频观看 | 午夜在线看片 | 韩国韩宝贝2020vip福利视频 | 天天拍夜夜添久久精品免费 | 午夜丁香婷婷 | 天天干天天干天天操 | 天天做天天添婷婷我也去 | 免费在线欧美 | 午夜亚洲福利 | 国产精品久久久久国产精品三级 | 国产色婷婷精品综合在线观看 | 亚洲香蕉网久久综合影院3p | 欧美不卡视频在线观看 | 午夜精品区| 人人澡人人澡碰人人看软件 | 一本高清在线视频 | 免费观看老外特级毛片 | 亚洲视频一 | 欧美中出 | 亚洲欧美日韩一区 | 色香蕉在线 | 欧美黄色大片免费 | 五月婷婷六月丁香在线 | 老湿司午夜爽爽影院榴莲视频 | 午夜黄网站 | www.色妞| 亚洲一区二区免费 |