一、字典的应用场景
思考1: 如果有多个数据,例如:‘Tom’, ‘男’, 20,如何快速存储?
答:列表
list1 = ['Tom', '男', 20]
思考2:如何查找到数据’Tom’?
答:查找到下标为0的数据即可。
list1[0]
思考3:如果将来数据顺序发生变化,如下所示,还能用list1[0]
访问到数据’Tom’吗?。
list1 = ['男', 20, 'Tom']
答:不能,数据’Tom’此时下标为2。
思考4:数据顺序发生变化,每个数据的下标也会随之变化,如何保证数据顺序变化前后能使用同一的标准查找数据呢?
答:字典,字典里面的数据是以键值对形式出现,字典数据和数据顺序没有关系,即字典不支持下标,后期无论数据如何变化,只需要按照对应的键的名字查找数据即可。
二、字典的概念
-
字典属于一种新的数据结构,称为映射(mapping)。
字典不再是序列,无法通过为止索引完成元素值的获取,只能通过键索引实现。
字典也是python中唯一内建的映射类型。
-
字典的作用和列表类似,都是用来存储对象的容器。
-
列表存储数据的性能很好,但是查询数据的性能的很差(要么知道下标,要么就要一个一个遍历)。
-
在字典中每一个元素都有一个唯一的名字,通过这个唯一的名字可以快速的查找到指定的元素。
-
在查询元素时,字典的效率是非常快的。
-
在字典中可以保存多个对象,每个对象都会有一个唯一的名字。
-
这个唯一的名字,我们称其为键(key),
通过key可以快速的查询value。
字典的键可以是任意的不可变对象(int、str、bool、tuple …),但是一般我们都会使用str。
字典的键是不能重复的,如果出现重复的后边的会替换到前边的。
-
这个对象,我们称其为值(value),字典的值可以是任意对象。
-
所以字典,我们也称为叫做键值对(key-value)结构。
-
每个字典中都可以有多个键值对,而每一个键值对我们称其为一项(item)。
-
三、创建字典的语法
字典特点:
- 符号为大括号。
- 数据为键值对形式出现。
- 各个键值对之间用逗号隔开。
# 1.创建有数据字典
dict1 = {'name': 'Tom', 'age': 20, 'gender': '男'}
print(type(dict1)) # <class 'dict'>
# 2.创建空字典
# 方式1
dict2 = {}
print(type(dict2)) # <class 'dict'>
# 方式2,通过dict()函数
dict3 = dict()
print(type(dict3)) # <class 'dict'>
# 3.使用dict()函数来创建有元素的字典
# 每一个参数都是一个键值对,参数名就是键,参数名就是值
# (这种方式创建的字典,key都是字符串)
d = dict(name='孙悟空', age=18, gender='男')
print(d) # {'name': '孙悟空', 'age': 18, 'gender': '男'}
print(type(d)) # <class 'dict'>
注意:一般称冒号前面的为键(key),简称k;冒号后面的为值(value),简称v。