Python學習小技巧之利用字典的默認行為
本文介紹的是關于Python利用字典的默認行為的相關內容,分享出來供大家參考學習,下面來看看詳細的介紹:
典型代碼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}
應用場景:
典型代碼1的應用場景:
在寫一些統(tǒng)計代碼的時候,總是需要統(tǒng)計一些key的個數(shù),用一個字典來存儲計數(shù)的結果,如果使用的是經典字典,那么我們每次都需要人工寫代碼來判斷對應的key是否存在,如果不存在還需要將其存入這個字典中,再將其初始化為0;而利用defaultdict數(shù)據(jù)類型,我們就可以直接指定一個工廠函數(shù)來為我們生產默認值,典型代碼1中使用的是內置的int函數(shù),當然也可以是lambda表達式定義的匿名函數(shù)。
典型代碼2的應用場景:
對于一個字典,如果我們只想保留每個key被第一次指定的值,如果用傳統(tǒng)的方法data['k']='v'的話,我們需要每次都要判斷相應的key是否已經存在于字典中,然后才能決定是否能夠設置這個key的值;二利用dict的setdefault方法,我們可以避免這次判斷,以更加簡潔的方式實現(xiàn)這個功能。
帶來的好處:
1. 場景2中的setdefault方法,在Python解釋器的實現(xiàn)中經過優(yōu)化,一般情況下要比自己寫的同樣功能的Python代碼執(zhí)行效率要高
2. 這兩種默認情形,都能夠使代碼更加緊湊,邏輯上,讀代碼時理解起來也更高效
其它說明:
1. defaultdict類型,可以接收很多的類型,內置的list, set, dict都可以直接使用,使用lambda匿名函數(shù),可以使用自己定義的類型
總結
好了,以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。