Python學(xué)習(xí)小技巧之利用字典的默認(rèn)行為
本文介紹的是關(guān)于Python利用字典的默認(rèn)行為的相關(guān)內(nèi)容,分享出來供大家參考學(xué)習(xí),下面來看看詳細(xì)的介紹:
典型代碼1:
from collections import defaultdict if __name__ == '__main__': data = defaultdict(int) data[0] += 1 print(data)
輸出1:
defaultdict(<type 'int'>, {0: 1})
典型代碼2:
if __name__ == '__main__': data = {'k': 1} data.setdefault('k', 100) data.setdefault('k1', -100) print(data)
輸出2:
{'k': 1, 'k1': -100}
應(yīng)用場景:
典型代碼1的應(yīng)用場景:
在寫一些統(tǒng)計代碼的時候,總是需要統(tǒng)計一些key的個數(shù),用一個字典來存儲計數(shù)的結(jié)果,如果使用的是經(jīng)典字典,那么我們每次都需要人工寫代碼來判斷對應(yīng)的key是否存在,如果不存在還需要將其存入這個字典中,再將其初始化為0;而利用defaultdict數(shù)據(jù)類型,我們就可以直接指定一個工廠函數(shù)來為我們生產(chǎn)默認(rèn)值,典型代碼1中使用的是內(nèi)置的int函數(shù),當(dāng)然也可以是lambda表達(dá)式定義的匿名函數(shù)。
典型代碼2的應(yīng)用場景:
對于一個字典,如果我們只想保留每個key被第一次指定的值,如果用傳統(tǒng)的方法data['k']='v'的話,我們需要每次都要判斷相應(yīng)的key是否已經(jīng)存在于字典中,然后才能決定是否能夠設(shè)置這個key的值;二利用dict的setdefault方法,我們可以避免這次判斷,以更加簡潔的方式實現(xiàn)這個功能。
帶來的好處:
1. 場景2中的setdefault方法,在Python解釋器的實現(xiàn)中經(jīng)過優(yōu)化,一般情況下要比自己寫的同樣功能的Python代碼執(zhí)行效率要高
2. 這兩種默認(rèn)情形,都能夠使代碼更加緊湊,邏輯上,讀代碼時理解起來也更高效
其它說明:
1. defaultdict類型,可以接收很多的類型,內(nèi)置的list, set, dict都可以直接使用,使用lambda匿名函數(shù),可以使用自己定義的類型
總結(jié)
好了,以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關(guān)文章
使用Python可設(shè)置抽獎?wù)邫?quán)重的抽獎腳本代碼
這篇文章主要介紹了Python可設(shè)置抽獎?wù)邫?quán)重的抽獎腳本,抽獎系統(tǒng)包含可給不同抽獎?wù)咴O(shè)置不同的權(quán)重,先從價值高的獎品開始抽,已經(jīng)中獎的人,不再參與后續(xù)的抽獎,本文通過實例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2022-11-11詳解設(shè)計模式中的工廠方法模式在Python程序中的運用
這篇文章主要介紹了設(shè)計模式中的工廠方法模式在Python程序中的運用,工廠方法模式主張程序在設(shè)計時要可以根據(jù)不同的條件生成各種類的實例,需要的朋友可以參考下2016-03-03Python Lambda函數(shù)使用總結(jié)詳解
這篇文章主要介紹了Python Lambda函數(shù)使用總結(jié)詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2019-12-12