圆月山庄资源网 Design By www.vgjia.com
dict的很多方法跟list有类似的地方,下面一一道来,并且会跟list做一个对比
嵌套
嵌套在list中也存在,就是元素是list,在dict中,也有类似的样式:
> a_list = [[1,2,3],[4,5],[6,7]] > a_list[1][1] 5 > a_dict = {1:{"name":"qiwsir"},2:"python","email":"qiwsir@gmail.com"} > a_dict {1: {'name': 'qiwsir'}, 2: 'python', 'email': 'qiwsir@gmail.com'} > a_dict[1]['name'] #一个嵌套的dict访问其值的方法:一层一层地写出键 'qiwsir'
获取键、值
在上一讲中,已经知道可以通过dict的键得到其值。例上面的例子。
还有别的方法得到键值吗?有!python一般不是只有一个方法实现某个操作的。
> 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语句循环得到相应内容。例如:
> 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'>
以下两种方法等效:
> for value in website.values(): ... print value ... google baidu facebook 4 > for key in website: ... print website[key] ... google baidu facebook 4
下面的方法又是等效的:
> 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
下面的方法也能得到键值,不过似乎要多敲键盘
> website {1: 'google', 'second': 'baidu', 3: 'facebook', 'twitter': 4} > website.get(1) 'google' > website.get("second") 'baidu'
其它几种常用方法
dict中的方法在这里不做过多的介绍,因为前面一节中已经列出来类,看官如果有兴趣可以一一尝试。下面列出几种常用的
> 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}
删除键值对的方法有两个,但是两者有一点区别
>#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中。
> 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'}
在本讲最后,要提醒看官,在python3中,dict有不少变化,比如能够进行字典解析,就类似列表解析那样,这可是非常有意思的东西哦。
圆月山庄资源网 Design By www.vgjia.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
圆月山庄资源网 Design By www.vgjia.com
暂无评论...
更新日志
2024年11月08日
2024年11月08日
- 雨林唱片《赏》新曲+精选集SACD版[ISO][2.3G]
- 罗大佑与OK男女合唱团.1995-再会吧!素兰【音乐工厂】【WAV+CUE】
- 草蜢.1993-宝贝对不起(国)【宝丽金】【WAV+CUE】
- 杨培安.2009-抒·情(EP)【擎天娱乐】【WAV+CUE】
- 周慧敏《EndlessDream》[WAV+CUE]
- 彭芳《纯色角3》2007[WAV+CUE]
- 江志丰2008-今生为你[豪记][WAV+CUE]
- 罗大佑1994《恋曲2000》音乐工厂[WAV+CUE][1G]
- 群星《一首歌一个故事》赵英俊某些作品重唱企划[FLAC分轨][1G]
- 群星《网易云英文歌曲播放量TOP100》[MP3][1G]
- 方大同.2024-梦想家TheDreamer【赋音乐】【FLAC分轨】
- 李慧珍.2007-爱死了【华谊兄弟】【WAV+CUE】
- 王大文.2019-国际太空站【环球】【FLAC分轨】
- 群星《2022超好听的十倍音质网络歌曲(163)》U盘音乐[WAV分轨][1.1G]
- 童丽《啼笑姻缘》头版限量编号24K金碟[低速原抓WAV+CUE][1.1G]