【python系统学习07】一张图看懂字典并学会操作
数据类型 - 字典(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”的值