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