python之dict()的操作方法
来源: 阅读:690 次 日期:2016-06-22 09:44:17
温馨提示: 小编为您整理了“python之dict()的操作方法”,方便广大网友查阅!

dict的很多方法跟list有类似的地方,下面一一道来,并且会跟list做一个对比

嵌套

嵌套在list中也存在,就是元素是list,在dict中,也有类似的样式:

?12345678 >>> a_list = [[1,2,3],[4,5],[6,7]] >>> a_list[1][1] 5>>> a_dict = {1:{name:qiwsir},2:python,email:} >>> a_dict {1: {'name': 'qiwsir'}, 2: 'python', 'email': } >>> a_dict[1]['name'] #一个嵌套的dict访问其值的方法:一层一层地写出键 'qiwsir'

获取键、值

在上一讲中,已经知道可以通过dict的键得到其值。例上面的例子。

还有别的方法得到键值吗?有!python一般不是只有一个方法实现某个操作的。

?1234567891011121314 >>> website = {1:google,second:baidu,3:facebook,twitter:4} >>>#用d.keys()的方法得到dict的所有键,结果是list >>> website.keys() [1, 'second', 3, 'twitter'] >>>#用d.values()的方法得到dict的所有值,如果里面没有嵌套别的dict,结果是list >>> website.values() ['google', 'baidu', 'facebook', 4] >>>#用items()的方法得到了一组一组的键值对, >>>#结果是list,只不过list里面的元素是元组 >>> website.items() [(1, 'google'), ('second', 'baidu'), (3, 'facebook'), ('twitter', 4)]

从上面的结果中,我们就可以看出,还可以用for语句循环得到相应内容。例如:

?12345678910111213141516 >>> for key in website.keys(): ... print key,type(key) ... 1 <type 'int'> second <type 'str'> 3 <type 'int'> twitter <type 'str'> >>>#下面的方法和上面的方法是一样的 >>> for key in website: ... print key,type(key) ... 1 <type 'int'> second <type 'str'> 3 <type 'int'> twitter <type 'str'>

以下两种方法等效:

?123456789101112131415 >>> for value in website.values(): ... print value ... google baidu facebook 4 >>> for key in website: ... print website[key] ... google baidu facebook 4

下面的方法又是等效的:

?123456789101112131415 >>> for k,v in website.items(): ... print str(k)+:+str(v) ... 1:google second:baidu 3:facebook twitter:4 >>> for k in website: ... print str(k)+:+str(website[k]) ... 1:google second:baidu 3:facebook twitter:4

下面的方法也能得到键值,不过似乎要多敲键盘

?123456 >>> website {1: 'google', 'second': 'baidu', 3: 'facebook', 'twitter': 4} >>> website.get(1) 'google'>>> website.get(second) 'baidu'

其它几种常用方法

dict中的方法在这里不做过多的介绍,因为前面一节中已经列出来类,看官如果有兴趣可以一一尝试。下面列出几种常用的

?12345678 >>> len(website) 4>>> website {1: 'google', 'second': 'baidu', 3: 'facebook', 'twitter': 4} >>> new_web = website.copy() #拷贝一份,这个拷贝也叫做浅拷贝,对应着还有深拷贝。 >>> new_web  #两者区别,可以google一下。 {1: 'google', 'second': 'baidu', 3: 'facebook', 'twitter': 4}

删除键值对的方法有两个,但是两者有一点区别

?1234567891011 >>>#d.pop(key),根据key删除相应的键值对,并返回该值 >>> new_web.pop('second') 'baidu' >>> del new_web[3]  #没有返回值,如果删除键不存在,返回错误 >>> new_web {1: 'google', 'twitter': 4} >>> del new_web[9] traceback (most recent call last): file <stdin>, line 1, in <module> keyerror: 9

用d.update(d2)可以把d2合并到d中。

?12345678910 >>> cnweb {'qq': 'first in cn', 'python': 'qiwsir.github.io', 'alibaba': 'business'} >>> website {1: 'google', 'second': 'baidu', 3: 'facebook', 'twitter': 4} >>> website.update(cnweb) #把cnweb合并到website内 >>> website  #变化了 {'qq': 'first in cn', 1: 'google', 'second': 'baidu', 3: 'facebook', 'python': 'qiwsir.github.io', 'twitter': 4, 'alibaba': 'business'} >>> cnweb  #not changed

{'qq': 'first in cn', 'python': 'qiwsir.github.io', 'alibaba': 'business'}

更多信息请查看脚本栏目
上一篇:htc教程
下一篇:js的优点
手机网站地址:python之dict()的操作方法
由于各方面情况的不断调整与变化, 提供的所有考试信息和咨询回复仅供参考,敬请考生以权威部门公布的正式信息和咨询为准!
关于我们 | 联系我们 | 人才招聘 | 网站声明 | 网站帮助 | 非正式的简要咨询 | 简要咨询须知 | 加入群交流 | 手机站点 | 投诉建议
工业和信息化部备案号:滇ICP备2023014141号-1 云南省教育厅备案号:云教ICP备0901021 滇公网安备53010202001879号 人力资源服务许可证:(云)人服证字(2023)第0102001523号
云南网警备案专用图标
联系电话:0871-65317125(9:00—18:00) 获取招聘考试信息及咨询关注公众号:hfpxwx
咨询QQ:526150442(9:00—18:00)版权所有:
云南网警报警专用图标
Baidu
map