字典的迭代與循環(huán)在 Python 中的優(yōu)秀實(shí)踐
字典是 Python 中非常常用的數(shù)據(jù)結(jié)構(gòu),用于存儲(chǔ)鍵值對(duì)。掌握字典的迭代與循環(huán)技巧對(duì)于提高編程效率至關(guān)重要。本文將詳細(xì)介紹字典的迭代與循環(huán)的最佳實(shí)踐,從基礎(chǔ)到高級(jí),一步步帶你掌握這些技能。

1. 基本的字典迭代
首先,我們來(lái)看如何遍歷字典中的鍵。這是最基礎(chǔ)的字典迭代方式。
# 創(chuàng)建一個(gè)字典
my_dict = {'a': 1, 'b': 2, 'c': 3}
# 遍歷字典的鍵
for key in my_dict:
    print(key)輸出結(jié)果:
a
b
c2. 遍歷字典的值
如果你只需要字典的值,可以使用 values() 方法。
# 遍歷字典的值
for value in my_dict.values():
    print(value)輸出結(jié)果:
1
2
33. 同時(shí)遍歷鍵和值
通常情況下,我們需要同時(shí)訪問(wèn)鍵和值。這時(shí)可以使用 items() 方法。
# 遍歷字典的鍵和值
for key, value in my_dict.items():
    print(f"Key: {key}, Value: {value}")輸出結(jié)果:
Key: a, Value: 1
Key: b, Value: 2
Key: c, Value: 34. 字典推導(dǎo)式
字典推導(dǎo)式是一種簡(jiǎn)潔的方式來(lái)創(chuàng)建新的字典。它也可以用于字典的迭代。
# 使用字典推導(dǎo)式創(chuàng)建新字典
new_dict = {key: value * 2 for key, value in my_dict.items()}
print(new_dict)輸出結(jié)果:
{'a': 2, 'b': 4, 'c': 6}5. 迭代字典的有序性
在 Python 3.7 及更高版本中,字典默認(rèn)是有序的。這意味著你可以在迭代時(shí)保持插入順序。
# 創(chuàng)建一個(gè)字典并按插入順序迭代
ordered_dict = {'apple': 1, 'banana': 2, 'cherry': 3}
for key in ordered_dict:
    print(key)輸出結(jié)果:
apple
banana
cherry6. 使用 enumerate 迭代字典
有時(shí)候你需要知道當(dāng)前迭代的索引位置,可以使用 enumerate 函數(shù)。
# 使用 enumerate 迭代字典
for index, (key, value) in enumerate(my_dict.items()):
    print(f"Index: {index}, Key: {key}, Value: {value}")輸出結(jié)果:
Index: 0, Key: a, Value: 1
Index: 1, Key: b, Value: 2
Index: 2, Key: c, Value: 37. 過(guò)濾字典項(xiàng)
你可以使用條件表達(dá)式來(lái)過(guò)濾字典中的項(xiàng)。
# 過(guò)濾字典中的項(xiàng)
filtered_dict = {key: value for key, value in my_dict.items() if value > 1}
print(filtered_dict)輸出結(jié)果:
{'b': 2, 'c': 3}8. 字典的合并
在 Python 3.9 及更高版本中,可以使用 | 操作符來(lái)合并字典。
# 合并兩個(gè)字典
dict1 = {'a': 1, 'b': 2}
dict2 = {'b': 3, 'c': 4}
merged_dict = dict1 | dict2
print(merged_dict)輸出結(jié)果:
{'a': 1, 'b': 3, 'c': 4}9. 高級(jí)技巧:使用 defaultdict
collections 模塊中的 defaultdict 可以在訪問(wèn)不存在的鍵時(shí)自動(dòng)初始化該鍵。
from collections import defaultdict
# 創(chuàng)建一個(gè) defaultdict
dd = defaultdict(int)
# 訪問(wèn)不存在的鍵
dd['a'] += 1
dd['b'] += 2
print(dd)輸出結(jié)果:
defaultdict(<class 'int'>, {'a': 1, 'b': 2})10. 實(shí)戰(zhàn)案例:統(tǒng)計(jì)單詞頻率
假設(shè)我們有一個(gè)文本文件,需要統(tǒng)計(jì)其中每個(gè)單詞出現(xiàn)的次數(shù)。我們可以使用字典來(lái)實(shí)現(xiàn)這個(gè)功能。
from collections import defaultdict
# 示例文本
text = "hello world hello python world"
# 分割文本為單詞列表
words = text.split()
# 創(chuàng)建一個(gè) defaultdict 來(lái)統(tǒng)計(jì)單詞頻率
word_count = defaultdict(int)
# 遍歷單詞列表并統(tǒng)計(jì)頻率
for word in words:
    word_count[word] += 1
# 打印結(jié)果
for word, count in word_count.items():
    print(f"Word: {word}, Count: {count}")輸出結(jié)果:
Word: hello, Count: 2
Word: world, Count: 2
Word: python, Count: 1總結(jié)
本文詳細(xì)介紹了字典的迭代與循環(huán)的最佳實(shí)踐,從基礎(chǔ)的鍵值遍歷到高級(jí)的字典推導(dǎo)式、過(guò)濾、合并等技巧。通過(guò)實(shí)際的代碼示例,我們逐步展示了每個(gè)概念的應(yīng)用方法。















 
 
 














 
 
 
 