数据类型 - 字典(dict)
目录:
一张图get字典
一张图get字典的些许知识点
如果图中知识点描述过于概括,请看下列细文:
字典是什么
js的对象
说到字典,前端同学可以理解其为:对象。因为python中的字典和js中的对象长的不能说很像,简直就是一样。
字典是一到多个一一对应的键值对儿元素组成的集合。
它同列表一样,也是复杂数据类型的一种。
其中,字典内的键名必须是字符串类型的,而键名所对应的值可以是任何类型的。
字典长啥样
说了这么多,字典到底啥样?揭开神秘面纱:
语法伪代码
列表变量名 = {
'字符串键名key1': 对应key1的值value1,
'字符串键名key2': 对应key2的值value2,
...(更多key、value对儿)
}
示例demo
一个字典定义的demo代码,可以留神下,接下来的案例可能会用到。
dictName = {
'name': '小石头',
'age': 19,
'hobby': {
'it': ['css','js','python'],
'daily': [['music','tv'],['apple','pear']],
'sports': 'sleep'
},
'married': True
}
语法成像
通过伪代码和demo代码我们可以总结出以下关于字典的特征点:
变量名自定义
等号将字典赋值给变量(dictName)
等号右边的是字典,用一对儿花括号包裹
字典内部是一对对的键值对(键:
key
; 值:value
)。键名用字符串
即键名必须用引号包裹,否则就会报错 错误类型: NameError
,变量未定义的错误
键名是需要唯一不重复的
如上,dictName中,只能有一个"age" 若有多个同名键,只保留最后一个键
keyNameOnly = {
'age': 29,
'age': 19,
'name': '小石头'
}
print(keyNameOnly)
# {'age': 19, 'name': '小石头'} age对应29的键值对被覆盖了值value可以任何类型
一个对象内值内容可重复
valueNameRepeat = {
'name': '小石头',
'like': '小石头',
'realTalk': True
}
print(valueNameRepeat)
# {'name': '小石头', 'like': '小石头', 'realTalk': True} 值‘小石头’重复也无所谓。键名与值之间用英文冒号连接
键(key)与值(value)形成的组合叫做键值对儿
每对儿键值对之间用英文逗号分隔
字典里可以有无数对儿键值对
最后一对儿键值对不需要逗号
字典怎么用
字典长度获取——len函数
我们可以用len()
函数来得出一个列表或者字典的长度(元素个数)
括号里放列表或字典名称
print(len(dictName)) #4,因为又4对儿,键名分别是name、age、hobby和married
列表的长度也是用len()函数获取
提取字典中的元素
通过字典的索引(键名)来获取对应的值
伪代码:
字典名[字典的键]
字典没有偏移量,所以中括号写的是键名
demo:
dictName['name'] # 小石头
嵌套提取
拓展 - 二维嵌套列表值的提取方法
同样是用偏移量来获取。
listdemo = [['music','tv'],['apple','pear']]
print(listdemo[1][1]) # pear
先用第一个偏移量获取最外边列表的第1个元素。得到列表['apple','pear']
后,再继续追加一个偏移量[1]获取得到的列表['apple','pear']
中第一个元素,打印出'pear'
拓展 - 多维嵌套字典中值的提取方法
因为是用键名,而不是偏移量的方法获取。所以感觉在理解逻辑上,比列表容易让初学者接受。
print(dictName['hobby']['sports']) # sleep
先用键名"hobby"获取其对应的值,再用“hobby”里的"sports"获取其sports自己对应的值。得到"sleep"
拓展 - 列表与字典互相嵌套时值的提取方法
举一反三,概念加强版
print(dictName['hobby']['daily'][0][0]) # music
往字典中增加元素
新增键值对要用到赋值语句
伪代码:
字典名[键] = 值
自我感觉很好理解。只需要在提取的基础上赋值即可。
⚠️但可能需要注意,如果键名是字典中已经存在的,再这么操作就会直接修改这个键的值。
示例代码:
dictName['homeland'] = 'china'
print(dictName)
删除字典中的元素
删除字典里键值对的代码是del语句
伪代码:
del 字典名[键]
示例代码:
del(dictName['married'])
print(dictName)
对比列表的异同
相同点
1、修改值时都是通过赋值:在列表和字典中,如果要修改元素,都可用赋值语句来完成
2、值类型支持任意嵌套:除基本数据类型外,列表可嵌套其他列表和字典,字典也可嵌套其他字典和列表。
不同点
1、比较相等时规则不同
列表中的元素是有自己明确的“位置”的,所以即使看似相同的元素,只要在列表所处的位置不同,它们就是两个不同的列表
而字典中的数据是随机排列的,所以相比时即使键调动顺序也不影响
代码观察:
students1 = ['小明','小红','小刚']
students2 = ['小明','小红','小刚']
print(students1 == students2)
# True 必须元素顺序、个数、内容皆一致则相同
students3 = ['小明','小红','小刚']
students4 = ['小明','小刚','小红']
print(students3 == students4)
# False 改变了一下顺序就不相等了
scores1 = {'小明':95,'小红':90,'小刚':100}
scores2 = {'小刚':100,'小明':95,'小红':90}
print(scores1 == scores2)
# True 只要两个字典中,键名及其分别对应的值都一一相等,则整个字典相等。
scores3 = {'小明':95,'小红':90,'小刚':100}
scores4 = {'小明':9,'小红':90,'小刚':100}
print(scores3 == scores4)
# False 这样,即使键名一一对应,键名所对应的值不同,最终结果不相等。
2、读取数据的方法不同
列表有序,要用偏移量定位
字典无序,可通过唯一的键来取值
观察代码:
# 提取列表中的数据 - 用偏移量/索引/下标
listdemo = ['apple','pear']
print(listdemo[1]) # pear
# 提取字典中的数据 - 用键名
keyNameOnly = {
'age': 29,
'age': 19,
'name': '小石头'
}
print(keyNameOnly['age']) # 19
练习题
you = {
'name': '',
'a': [{
'b': {
'c': '强撑',
'love': 'anybody'
}
}],
'age': 30
}
4、在b里边增加爱好,为一个数组,数组内容自定
3、删除“age”
2、修改“name”的值
1、提取出“love”的值