Python中的defaultdict是一個非常有用的數(shù)據(jù)結(jié)構(gòu),它是一個字典(dict)的子類,可以為字典中不存在的鍵提供一個默認值。這個默認值可以是任何Python對象,例如整數(shù)、浮點數(shù)、字符串、列表等等。在使用defaultdict時,如果我們訪問字典中不存在的鍵,它會返回一個默認值,而不是拋出KeyError異常。
defaultdict的用法非常簡單,我們只需要在創(chuàng)建defaultdict對象時指定一個默認工廠函數(shù)即可。這個工廠函數(shù)會在我們訪問不存在的鍵時被調(diào)用,返回一個默認值。
_x000D_下面是一個示例代碼:
_x000D_`python
_x000D_from collections import defaultdict
_x000D_d = defaultdict(int)
_x000D_d['a'] = 1
_x000D_d['b'] = 2
_x000D_print(d['a']) # 輸出 1
_x000D_print(d['b']) # 輸出 2
_x000D_print(d['c']) # 輸出 0,因為int()函數(shù)返回0
_x000D_ _x000D_在上面的代碼中,我們使用了一個默認工廠函數(shù)int(),它返回整數(shù)0。當我們訪問字典中不存在的鍵時,它會返回0。
_x000D_除了int()函數(shù),defaultdict還支持其他的默認工廠函數(shù),例如list、set、lambda等等。我們可以根據(jù)具體的需求來選擇合適的工廠函數(shù)。
_x000D_下面是一個使用list作為默認工廠函數(shù)的示例代碼:
_x000D_`python
_x000D_from collections import defaultdict
_x000D_d = defaultdict(list)
_x000D_d['a'].append(1)
_x000D_d['b'].append(2)
_x000D_print(d['a']) # 輸出 [1]
_x000D_print(d['b']) # 輸出 [2]
_x000D_print(d['c']) # 輸出 [],因為list()函數(shù)返回一個空列表
_x000D_ _x000D_在上面的代碼中,我們使用了一個默認工廠函數(shù)list(),它返回一個空列表。當我們訪問字典中不存在的鍵時,它會返回一個空列表,并且我們可以直接在這個空列表上進行append操作。
_x000D_擴展問答:
_x000D_1. defaultdict和普通字典有什么區(qū)別?
_x000D_答:默認情況下,當我們訪問一個普通字典中不存在的鍵時,它會拋出KeyError異常。而使用defaultdict時,它會返回一個默認值,避免了KeyError異常的出現(xiàn)。使用defaultdict還可以避免在向字典中添加新鍵時需要判斷鍵是否存在的情況。
_x000D_2. defaultdict的默認工廠函數(shù)可以是任何Python對象嗎?
_x000D_答:是的,defaultdict的默認工廠函數(shù)可以是任何Python對象,包括整數(shù)、浮點數(shù)、字符串、列表、字典、元組、集合、函數(shù)等等。
_x000D_3. 如果我想要在defaultdict中使用自定義的默認工廠函數(shù),應(yīng)該怎么做?
_x000D_答:我們可以使用lambda表達式來定義一個匿名函數(shù)作為默認工廠函數(shù)。例如,如果我們想要使用一個默認值為1的字典,可以使用下面的代碼:
_x000D_`python
_x000D_from collections import defaultdict
_x000D_d = defaultdict(lambda: 1)
_x000D_d['a'] = 2
_x000D_print(d['a']) # 輸出 2
_x000D_print(d['b']) # 輸出 1,因為lambda表達式返回1
_x000D_ _x000D_在上面的代碼中,我們使用了一個lambda表達式,它返回常數(shù)1。當我們訪問字典中不存在的鍵時,它會返回1。
_x000D_4. defaultdict的性能是否比普通字典差?
_x000D_答:由于defaultdict需要在訪問不存在的鍵時調(diào)用默認工廠函數(shù),因此它的性能可能略低于普通字典。在大多數(shù)情況下,這個性能差異是可以忽略不計的。如果在性能要求較高的場景中,可以使用普通字典來代替defaultdict。
_x000D_