99精品伊人亚洲|最近国产中文炮友|九草在线视频支援|AV网站大全最新|美女黄片免费观看|国产精品资源视频|精彩无码视频一区|91大神在线后入|伊人终合在线播放|久草综合久久中文

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

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

3天內(nèi)不再提示

Python模塊Addict的安裝與使用

python爬蟲知識分享 ? 來源:python爬蟲知識分享 ? 作者:python爬蟲知識分享 ? 2022-06-21 16:14 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

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

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

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 繼承自字典,但在訪問和設(shè)置其值方面更加靈活。使用 Addict 的字典是一種樂趣!
設(shè)置嵌套詞典的項是極其舒服的:

>>> 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

當然,此特點僅限于構(gòu)造函數(shù),而不是在使用屬性或設(shè)置值時:

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

3.要牢記的事情

記住,int不是有效的屬性名,因此必須使用 get/setitem 語法 設(shè)置/獲取 非字符串的 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.轉(zhuǎn)化為普通字典

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

>>> 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'

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

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.計數(shù)

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

比如以下數(shù)據(jù):

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)

# 結(jié)果:{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創(chuàng)建Elasticsearch查詢的繁瑣過程中發(fā)展而來的。每當你發(fā)現(xiàn)自己在寫了很復雜的字典邏輯時,只要記住你沒有必要這樣做,使用 Addict 就行。

審核編輯:湯梓紅

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

    關(guān)注

    7

    文章

    2788

    瀏覽量

    50423
  • 代碼
    +關(guān)注

    關(guān)注

    30

    文章

    4900

    瀏覽量

    70765
  • python
    +關(guān)注

    關(guān)注

    56

    文章

    4827

    瀏覽量

    86787
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    linux虛擬環(huán)境中調(diào)用Linux 版matlab編譯的python庫時出錯

    、readme.txt、 requiredMCRProducts.txt、init.py、CAO_python.ctf。 在linux環(huán)境中按照以下步驟安裝matlab runtime2018b: ① cd到MCR
    發(fā)表于 07-18 10:40

    ?如何在虛擬環(huán)境中使用 Python,提升你的開發(fā)體驗~

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

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

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

    使用Python實現(xiàn)xgboost教程

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

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

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

    EMMC存儲模塊安裝與配置

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

    Triton編譯器安裝步驟詳解

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

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

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

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

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

    如何使用Python構(gòu)建LSTM神經(jīng)網(wǎng)絡(luò)模型

    構(gòu)建一個LSTM(長短期記憶)神經(jīng)網(wǎng)絡(luò)模型是一個涉及多個步驟的過程。以下是使用Python和Keras庫構(gòu)建LSTM模型的指南。 1. 安裝必要的庫 首先,確保你已經(jīng)安裝Python
    的頭像 發(fā)表于 11-13 10:10 ?1584次閱讀

    LORA模塊安裝與配置指南

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

    Python常用函數(shù)大全

    Python 世界里,有一些寶藏函數(shù)和模塊,它們可以讓你編程更輕松、代碼更高效。這篇文章將帶你一一認識這些神器,讓你的開發(fā)生活瞬間輕松不少!
    的頭像 發(fā)表于 10-27 17:20 ?919次閱讀

    電源升壓模塊電路安裝操作步驟

    電源升壓模塊電路的安裝操作步驟主要包括以下幾個關(guān)鍵步驟: 一、準備階段 確認模塊規(guī)格 :首先,需要確認升壓模塊的輸入電壓范圍、輸出電壓、最大電流等規(guī)格參數(shù),確保所選
    的頭像 發(fā)表于 09-29 16:44 ?1901次閱讀

    python寫驗證環(huán)境cocotb

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

    安裝esp-idf-tools-setup-offline-5.1.2.exe到結(jié)尾運行python時顯示應用程序無法正常啟動如何解決?

    安裝esp-idf-tools-setup-offline-5.1.2.exe到結(jié)尾運行python時顯示應用程序無法正常啟動(0xc000007b),如何解決
    發(fā)表于 07-24 07:50