python键盘输入字典类型_python数据类型——字典类型

字典(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 indic5:print(i,dic5[i])for i,v indic5.items():print(i,v)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值