Python 遍历字典

一个Python字典可能只包含几个键—值对,也可能包含数百万个键—值对。鉴于字典可能包含大量的数据,Python支持对字典遍历。字典可用于以各种方式存储信息,因此有多种遍历字典的方式:可遍历字典的所有键—值对、键或值。

遍历所有的键—值对

探索各种遍历方法前,先来看一个新字典,它用于存储有关网站用户的信息。下面的字典存储一名用户的用户名、名和姓:

user_0 = {
        'username' : 'coolcou',
        'first' : 'enrico',
        'last' : 'coolcou'
    }

利用前面介绍过的知识,可访问user_0的任何一项信息,但如果要获悉该用户字典中的所有信息,该怎么办呢?可以使用一个for循环来遍历这个字典:

user_0 = {
        'username' : 'coolcou',
        'first' : 'enrico',
        'last' : 'coolcou'
    }
for key, value in user_0.items():
    print("Key: " + key)  #(1)
    print("Value: " + value) #(2)

如上所示,要编写用于遍历字典的for循环,可声明两个变量,用于存储键—值对中的键和值。对于这两个变量,可使用任何名称。下面的代码使用了简单的变量名,这完全可行:

for key, value in user_0.items()

for语句的第二部分包含字典名和方法items(),它返回一个键—值对列表。接下来,for循环依次将每个键—值对存储到指定的两个变量中。在前面的示例中,我们使用这两个变量来打印每个键(见(1))及其相关联的值(见(2))。第一条print语句中的”\n”确保在输出每个键—值对前都插入一个空行:

Key: first
Value: enrico
Key: username
Value: coolcou
Key: last
Value: coolcou

注意,即便遍历字典时,键—值对的返回顺序也与存储顺序不同。Python不关心键—值对的存储顺序,而只跟踪键和值之间的关联关系。

遍历字典中的所有键

在不需要使用字典中的值时,方法keys()很有用。下面来遍历字典favorite_languages,并将每个被调查者的名字都打印出来:

favorite_languages = {
    'jen' : 'python',
    'sarah' : 'c',
    'edward' : 'ruby',
    'coolcou' : 'python'
}
for name in favorite_languages.keys(): #(1)
    print(name.title())

(1)处的代码行让Python提取字典favorite_languages中的所有键,并依次将它们存储到变量name中。输出列出了每个被调查者的名字:

Jen
Sarah
Coolcou
Edward

遍历字典时,会默认遍历所有的键,因此,如果将上述代码中的for name infavorite_languages.keys():替换为for name in favorite_languages:,输出将不变。

如果显式地使用方法keys()可让代码更容易理解,你可以选择这样做,但如果你愿意,也可省略它。

按顺序遍历字典中的所有键

字典总是明确地记录键和值之间的关联关系,但获取字典的元素时,获取顺序是不可预测的。这不是问题,因为通常你想要的只是获取与键相关联的正确的值。

要以特定的顺序返回元素,一种办法是在for循环中对返回的键进行排序。为此,可使用函数sorted()来获得按特定顺序排列的键列表的副本:

favorite_languages = {
    'jen' : 'python',
    'sarah' : 'c',
    'edward' : 'ruby',
    'coolcou' : 'python'
}
for name in sorted(favorite_languages.keys()):
    print(name.title() + ", thank you for taking the poll.")

这条for语句类似于其他for语句,但对方法dictionary.keys()的结果调用了函数sorted()。这让Python列出字典中的所有键,并在遍历前对这个列表进行排序。输出表明,按顺序显示了所有被调查者的名字:

Coolcou, thank you for taking the poll.
Edward, thank you for taking the poll.
Jen, thank you for taking the poll.
Sarah, thank you for taking the poll.

遍历字典中的所有值

如果你感兴趣的主要是字典包含的值,可使用方法values(),它返回一个值列表,而不包含任何键。例如,如果我们想获得一个这样的列表,即其中只包含被调查者选择的各种语言,而不包含被调查者的名字,可以这样做:

favorite_languages = {
    'jen' : 'python',
    'sarah' : 'c',
    'edward' : 'ruby',
    'coolcou' : 'python'
}
print("The following languages have been mentioned:")
for language in favorite_languages.values():
    print(language.title())

这条for语句提取字典中的每个值,并将它们依次存储到变量language中。通过打印这些值,就获得了一个列表,其中包含被调查者选择的各种语言:

The following languages have been mentioned:
Python
Python
Ruby
C

这种做法提取字典中所有的值,而没有考虑是否重复。涉及的值很少时,这也许不是问题,但如果被调查者很多,最终的列表可能包含大量的重复项。为剔除重复项,可使用集合set)。集合类似于列表,但每个元素都必须是独一无二的:

favorite_languages = {
    'jen' : 'python',
    'sarah' : 'c',
    'edward' : 'ruby',
    'coolcou' : 'python'
}
print("The following languages have been mentioned:") #(1)
for language in set(favorite_languages.values()):
    print(language.title())

通过对包含重复元素的列表调用set(),可让Python找出列表中独一无二的元素,并使用这些元素来创建一个集合。在(1)处,我们使用了set()来提取favorite_languages.values()中不同的语言。

结果是一个不重复的列表,其中列出了被调查者提及的所有语言:

The following languages have been mentioned:
Python
C
Ruby

随着你更深入地学习Python,经常会发现它内置的功能可帮助你以希望的方式处理数据。

赞(0)

评论 抢沙发

评论前必须登录!