字典(dictionary)
python中唯一的映射类型,采用键值对(key-value)的形式储存数据,python对key进行哈希函数运算,所以key值必须是可哈希的,可哈希表示key必须是不可变的,如:数字、字符串、元组,元组的值value可以为所有类型的数据。系统根据哈西的计算结果储存value的地址,所以字典是无序的。
相对于列表,字典是通过键来存取,二列表是通过偏移(下标)来存取。
方便理解:元组相当于一个大旅馆,旅馆中有很多很多的房间,存数据相当于房间中住人或者放各种东西,key相当于门牌号,这个门牌号是在旅馆不能动且一定唯一,因为门牌号一改,整个旅馆的房间就乱了。房间中的东西相当于value,每个房间中可以随意的放任何种类的东西,住人啊,放行李啊,电器什么的,就相当于value可以是任何种类的数据。这样旅馆中门牌号可以是无序的,因为每个房间和门牌号是一一对应的,所以只要找对门牌号就可以找到指定房间。
字典的创建
dic1={'name':'cai','game':"lol",'age':8}
print(dic1)
格式:d = {key1 : value1, key2 : value2 }每一个key对应一个value。
增删改查
增加
dic2={'name':"li",'hobby':"money"}
dic2['age']=8#添加'age':8
print(dic2)
dic2.setdefault('age',24)#键存在,不改动,返回键对应的原值;键不存在,在字典中添加键和值,并返回新添加的值。
两种方式,一种用d[key]=value直接添加新的值,一种用setdefault方法。若不想影响字典中原有数据,单纯的添加setdafult方法相对安全;d[key]=value若字典中原来已有该key,将会把value覆盖更新。
查找
a=dic2['age']#把'age'对应的值赋给a
print(a)
print(dic2.keys())#输出所有的键(key)
print(dic2.values())#输出所有的值(value)
print(dic2.items())#以元组方式输出所有键-值(key-value)
查找很简单,d[key]可直接获得键对应的值,并可用自带方法输出相应数据。
修改
dic2['age']=22
print(dic2)
d[key]=value,有则改之,无则添加。
另有update方法:
dic2.update(dic1)
print(dic2)
该方法会将dic1中的所有键值添加到dic2,若dic2中有和dic1中的键相同,则dic2中对应的值将会被覆盖。
删除
del dic2['age']
print(dic2)
类似列表,可以用del d[key]删除对应键值。同样也有pop和clear方法:
dic2.pop('age')#删除键age的键和值,返回删除的值
dic1.clear()#清空整个字典
del dic2#删除整个字典
字典的嵌套
既然字典中的value可以是任何类型的数据,那value也可以是字典类型,字典中的字典就是嵌套。举个例子:
dic4={
'文件夹':{
'games':{
'FC':['坦克大战','魂斗罗','超级玛丽'],
'MD':['新光明与黑暗','梦幻之星4千年终结','雪人兄弟'],
'GBA':['口袋妖怪漆黑的魅影','铸剑物语','火焰纹章','超级机器人大战'],
}
}
}
我这个dic4按照我电脑的一个文件夹创建。那么字典以内的字典如何查看修改呢。
x=dic4['文件夹']['games']['FC'][1]
print(x)
dic4['文件夹']['games']['FC'][1]='雪人兄弟'
print(dic4)
字典的嵌套类似文件夹,有层级关系。用[]进入一层字典,在下一层再用[]进入再下一层,类推。可以进入任何一层进行访问修改删除等操作。
还有排序函数:
print(sorted(dic4['文件夹']['games']))
可以用sorted函数对子典的一层内容进行排序,可以是key,value,或者key-value.
字典的遍历
可以通过for循环进行对整个字典内数据的获取:
dic5={'name':"li",'hobby':"money"}
for i in dic5:
print(i,dic5[i])
for i,v in dic5.items():
print(i,v)