1、一个简单的字典
person = {'name': 'Polumgla', 'age': 18, 'sex': 'man'}
print(person['name'])
print(person['age'])
print(person['sex'])
输出是:
2、使用字典
在Python中,字典是一系列键—值对 。每个键都与一个值相关联,你可以使用键来访问与之相关联的值。与键相关联的值可以是数字、字符串、列表乃至字典。事实上,可将 任何Python对象用作字典中的值。
在Python中,字典用放在花括号{} 中的一系列键—值对表示。如前面的示例:
person = {'name': 'Polumgla', 'age': 18, 'sex': 'man'}
键—值 对是两个相关联的值。指定键时,Python将返回与之相关联的值。键和值之间用冒号分隔,而键—值对之间用逗号分隔。在字典中,你想存储多少个键—值对都可以。 最简单的字典只有一个键—值对,如下述 所示:
dictionary = {'key': 'value'}
2.1 访问字典中的值
要获取与键相关联的值,可依次指定字典名和放在方括号内的键
person = {'name': 'Polumgla', 'age': 18, 'sex': 'man'}
print(person['name'])
print(person['age'])
print(person['sex'])
再使用键对应的值的时候,要注意值的类型,防止类型错误
2.2 添加 键—值 对
字典是一种动态结构,可随时在其中添加键—值对。要添加键—值对,可依次指定字典名、用方括号括起的键和相关联的值。
person = {'name': 'Polumgla', 'age': 18, 'sex': 'man'}
person['height'] = 180
person['weight'] = 70
print(person)
输出是:
2.3 修改字典中的值
要修改字典中的值,可依次指定字典名、用方括号括起的键以及与该键相关联的新值
person = {'name': 'Polumgla', 'age': 18, 'sex': 'man'}
print(person['age'])
person['age'] = 22
print(person['age'])
输出是:
2.4 删除键—值对
对于字典中不再需要的信息,可使用del 语句将相应的键—值对彻底删除。使用del 语句时,必须指定字典名和要删除的键。
person = {'name': 'Polumgla', 'age': 18, 'sex': 'man'}
print(person)
del person['age']
print(person)
输出是:
2.5 由类似对象组成的字典
也可以使用字典来存储众多对象的同一种信息,如众人喜欢的变成语言:
favorite_languages = {
'jen': 'Python',
'sarah': 'C',
'edward': 'ruby',
'phil': 'Python'
}
print("Sarah's favorite language is " +
favorite_languages['sarah'].title() +
'.')
输出是:
需要使用多行来定义字典时,在输入左花括号后按回车键,再在下一行缩进四个空格,指定第一个键—值对,并在它后面加上一个逗号。此后你再次按回车键时,文本编辑器将自动缩进后续键—值对,且缩进量与第一个键—值对相同。
单词print 比大多数字典名都短,因此让输出的第一部分紧跟在左括号后面是合理的。请选择在合适的地方拆分要打印的内容,并在第一行末尾加上一个拼接运算符(+ )。按回车键进入print 语句的后续各行,并使用Tab键将它们对齐并缩进一级。指定要打印的所有内容 后,在print 语句的最后一行末尾加上右括号。
3、遍历字典
3.1 遍历所有键—值对
字典可用于以各种方式存储信息,因此有多种 遍历字典的方式:可遍历字典的所有键—值对、键或值。
要编写用于遍历字典的for 循环,可声明两个变量,用于存储键—值对中的键和值。对于这两个变量,可使用任何名称。
favorite_languages = {
'jen': 'Python',
'sarah': 'C',
'edward': 'ruby',
'phil': 'Python'
}
for name, language in favorite_languages.items():
print(name.title() + '`s favorite language is ' +
language.title() + '.')
输出是:
遍历字典时,键—值对的返回顺序也与存储顺序不同。Python不关心键—值对的存储顺序,而只跟踪键和值之间的关联关系。
3.2 遍历字典中的所有键
使用方法 keys()
favorite_languages = {
'jen': 'Python',
'sarah': 'C',
'edward': 'ruby',
'phil': 'Python'
}
for name in favorite_languages.keys():
print(name.title())
输出是:
keys() 它返回一个列表,其中包含字典中的所有键
favorite_languages = {
'jen': 'Python',
'sarah': 'C',
'edward': 'ruby',
'phil': 'Python'
}
print(favorite_languages.keys())
输出是:
3.3 按顺序遍历字典中的所有键
字典总是明确地记录键和值之间的关联关系,但获取字典的元素时,获取顺序是不可预测的。
要以特定的顺序返回元素,一种办法是在for 循环中对返回的键进行排序。为此,可使用函数sorted() 来获得按特定顺序排列的键列表的副本:
favorite_languages = {
'jen': 'Python',
'sarah': 'C',
'edward': 'ruby',
'phil': 'Python'
}
for name in sorted(favorite_languages.keys()):
print(name)
输出是:
3.4 遍历字典中的所有值
如果你感兴趣的主要是字典包含的值,可使用方法values() ,它返回一个值列表,而不包含任何键。
favorite_languages = {
'jen': 'Python',
'sarah': 'C',
'edward': 'ruby',
'phil': 'Python'
}
for language in favorite_languages.values():
print(language)
输出是:
这种做法提取字典中所有的值,而没有考虑是否重复。涉及的值很少时,这也许不是问题,但如果被调查者很多,最终的列表可能包含大量的重复项。为剔除重复项,可使用集合(set)。集合类似于列表,但每个元素都是独一无二的。
favorite_languages = {
'jen': 'Python',
'sarah': 'C',
'edward': 'ruby',
'phil': 'Python'
}
for language in set(favorite_languages.values()):
print(language)
输出是:
通过对包含重复元素的列表调用set() ,可让Python找出列表中独一无二的元素,并使用这些元素来创建一个集合。
4、嵌套
4.1 字典列表
把字典当作列表的元素
people_1 = {'name' : 'alen', 'age' : 18, 'sex' : 'man'}
people_2 = {'name' : 'howe', 'age' : 22, 'sex' : 'man'}
people_3 = {'name' : 'lily', 'age' : 12, 'sex' : 'women'}
peoples = [people_1, people_2, people_3]
for people in peoples:
print(people)
输出是:
4.2 在字典中存储列表
people = {'name' : 'howe', 'informations' : ['man', 22, '158xxxxxxxx']}
for information in people['informations']:
print(information)
输出是:
4.3 在字典中存储字典
peoples = {'lily' : {'age' : 10, 'sex' : 'women'},
'howe' : {'age' : 22, 'sex' : 'man'},
'alen' : {'age' : 18, 'sex' : 'man'}}
for name, info in peoples.items():
print(name.title() + '`s age is ' + str(info['age']) + ', sex is ' + info['sex'])
输出是: