亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Python中defaultdict方法常見的使用方法及問題解答

 更新時間:2025年07月03日 11:17:00   作者:余弦的倒數(shù)  
Python?defaultdict?是?collections?模塊的?dict?子類,自動處理缺失鍵,這篇文章主要介紹了Python中defaultdict方法常見的使用方法及問題解答,文中通過代碼介紹的非常詳細,需要的朋友可以參考下

前言

在 Python 中, defaultdict 是 collections 模塊提供的一個非常有用的類,它是內(nèi)置字典類型 dict 的子類。 defaultdict 的主要特點是 自動處理字典中不存在的鍵,避免在使用普通字典時因訪問不存在的鍵而拋出 KeyError 異常。

核心特點

  • 自動初始化默認值:當(dāng)訪問一個不存在的鍵時,defaultdict 會調(diào)用指定的默認工廠函數(shù)(default_factory)生成一個初始值,確定了字典中值的類型。
  • 簡化代碼:無需手動檢查鍵是否存在,適合需要分組、統(tǒng)計或聚合數(shù)據(jù)的場景。

基本語法

from collections import defaultdict

d = defaultdict(default_factory)
  • default_factory:一個可調(diào)用對象(如 listintsetstr 或自定義函數(shù)),用于生成默認值。

常見使用場景

1. 分組數(shù)據(jù)(默認值為列表)

將數(shù)據(jù)按鍵分組,類似 SQL 的 GROUP BY

from collections import defaultdict

data = [("apple", "fruit"), ("carrot", "vegetable"), ("apple", "fruit")]
grouped = defaultdict(list)

for name, category in data:
    grouped[category].append(name)

print(grouped)
# 輸出:defaultdict(<class 'list'>, {'fruit': ['apple', 'apple'], 'vegetable': ['carrot']})

2. 計數(shù)(默認值為整數(shù))

統(tǒng)計元素出現(xiàn)次數(shù):

from collections import defaultdict

text = "apple banana apple orange banana"
words = text.split()
count = defaultdict(int)

for word in words:
    count[word] += 1

print(count)
# 輸出:defaultdict(<class 'int'>, {'apple': 2, 'banana': 2, 'orange': 1})

3. 集合操作(默認值為集合)

避免重復(fù)值:

from collections import defaultdict

pairs = [("a", 1), ("b", 2), ("a", 3)]
unique = defaultdict(set)

for key, value in pairs:
    unique[key].add(value)

print(unique)
# 輸出:defaultdict(<class 'set'>, {'a': {1, 3}, 'b': {2}})

4. 嵌套字典

構(gòu)建多層嵌套結(jié)構(gòu):

from collections import defaultdict

nested = defaultdict(lambda: defaultdict(int))
nested["fruit"]["apple"] += 1
nested["vegetable"]["carrot"] += 2

print(nested["fruit"])        # 輸出:defaultdict(<class 'int'>, {'apple': 1})
print(nested["unknown_key"])  # 輸出:defaultdict(<class 'int'>, {})

注意事項

  • default_factory 必須可調(diào)用:例如 list、int 是類(構(gòu)造函數(shù)),而 list() 或 int() 的返回值不可作為工廠。
  • 僅對 d[key] 有效:使用 d.get(key) 或 key in d 不會觸發(fā)默認值生成。
  • 性能:與普通字典性能接近,適合高頻插入操作。

與普通字典對比

# 普通字典需要手動處理缺失鍵
d = {}
key = "unknown"
if key not in d:
    d[key] = []
d[key].append(1)

# defaultdict 自動處理
d = defaultdict(list)
d["unknown"].append(1)

總結(jié)

defaultdict 簡化了需要初始化默認值的字典操作,特別適合數(shù)據(jù)聚合、分組和統(tǒng)計場景。通過合理選擇 default_factory(如 listint、set 或自定義函數(shù)),可以大幅提升代碼簡潔性和可讀性。

在 Python 中,defaultdict 繼承自 dict,因此它的 鍵(Key)和值(Value)的類型規(guī)則與普通字典一致,但也有一些細節(jié)需要注意。以下是詳細說明:

1. 鍵(Key)的類型

  • 規(guī)則:鍵必須是 不可變類型(Immutable) 且 可哈希(Hashable)。

  • 允許的類型

    • 基本類型:intfloatstrboolNone
    • 不可變?nèi)萜鳎?code>tuple(但元組內(nèi)的元素也必須不可變)
    • frozenset(不可變集合)
    • 用戶自定義的不可變對象(需正確實現(xiàn) __hash__ 和 __eq__ 方法)。
  • 禁止的類型

    • 可變類型:listdictset
    • 包含可變元素的 tuple(例如 (1, [2, 3]))。
  • 示例

    from collections import defaultdict
    
    # 合法鍵
    d = defaultdict(int)
    d["apple"] = 10       # 字符串作為鍵 ?
    d[123] = 20          # 整數(shù)作為鍵 ?
    d[(1, 2)] = 30       # 不可變元組作為鍵 ?
    
    # 非法鍵(會拋出 TypeError)
    d[[1, 2]] = 40       # 列表不可哈希 ?
    d[{"a": 1}] = 50     # 字典不可哈希 ?
    

2. 值(Value)的類型

  • 規(guī)則:值可以是 任意類型,包括可變對象。

  • 允許的類型

    • 基本類型(intfloatstr 等)
    • 可變?nèi)萜鳎?code>list, dictset
    • 自定義對象、函數(shù)、類實例等。
  • 示例

    from collections import defaultdict
    
    # 值可以是列表(可變)
    d_list = defaultdict(list)
    d_list["fruits"].append("apple")
    
    # 值可以是字典(可變)
    d_dict = defaultdict(dict)
    d_dict["data"]["count"] = 10
    
    # 值可以是自定義對象
    class MyClass:
        pass
    
    d_obj = defaultdict(MyClass)
    obj = d_obj["instance"]  # 自動生成一個 MyClass 實例
    

3. default_factory 的返回值

default_factory 是一個可調(diào)用對象(如 listint 或自定義函數(shù)),它決定了 當(dāng)鍵不存在時,默認值的類型。例如:

  • defaultdict(list):默認值是一個空列表([])。
  • defaultdict(int):默認值是 0。
  • defaultdict(lambda: "unknown"):默認值是字符串 "unknown"。

值的類型完全由 default_factory 決定,與鍵的類型無關(guān)。

4. 嵌套 defaultdict 的鍵值

可以創(chuàng)建多層嵌套的 defaultdict,鍵的規(guī)則依然適用:

from collections import defaultdict

# 嵌套 defaultdict(值類型是另一個 defaultdict)
nested = defaultdict(lambda: defaultdict(int))

# 合法操作
nested["fruit"]["apple"] += 1      # 鍵為 "fruit"(字符串)和 "apple"(字符串)
nested[123][(4, 5)] = 2           # 鍵為 123(整數(shù))和 (4, 5)(不可變元組)

# 非法操作(內(nèi)層鍵非法)
nested["data"][[1, 2]] = 3        # 內(nèi)層鍵為列表,不可哈希 ?

5. 鍵和值的可變性總結(jié)

特性鍵(Key)值(Value)
類型限制必須不可變且可哈希可以是任意類型
可變性不可變可以可變
示例intstrtuplelistdict, 自定義對象

常見問題解答

Q1:可以用 list 作為鍵嗎?

  • 。列表是可變類型,不可哈希。若需用類似列表的結(jié)構(gòu)作為鍵,可以轉(zhuǎn)換為不可變的 tuple。

Q2:可以用 defaultdict 作為鍵嗎?

  • 。defaultdict 是可變對象,不可哈希。只有不可變類型(如 frozenset)可以作為鍵。

Q3:值可以是函數(shù)或類嗎?

  • 。例如:
    d = defaultdict(type)  # 默認值是類對象
    d["my_class"] = MyClass
    

總結(jié)

  • :必須為不可變且可哈希的類型(如 strinttuple)。
  • :可以是任意類型(包括可變對象),具體由 default_factory 決定。
  • 嵌套結(jié)構(gòu):可以自由嵌套 defaultdict,但需確保每一層的鍵合法。

到此這篇關(guān)于Python中defaultdict方法常見的使用方法及問題解答的文章就介紹到這了,更多相關(guān)Python defaultdict方法使用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評論