字典操作
字典是一种key-value的数据类型,使用的是就像我们上学用的字典,通过笔画,字母来查询对应页的详细内容
语法
info = {
'actor01':'武藤兰',
'actor02':'泷泽萝拉',
'avtor03':'小泽玛利亚',
}
特性:
(1)dict是无序的
(2)key必须是唯一的,自带去重属性
增加
>>> info['actor04']='波多野结衣'
>>> info
{'actor01': '武藤兰', 'actor02': '泷泽萝拉', 'avtor03': '小泽玛利亚', 'actor04': '波多野结衣'}
修改
>>> info['actor']='苍井空'
>>> info
{'actor01': '武藤兰', 'actor02': '泷泽萝拉', 'avtor03': '小泽玛利亚', 'actor04': '波多野结衣', 'actor': '苍井空'}
查找
>>> info
{'actor01': '武藤兰', 'actor02': '泷泽萝拉', 'avtor03': '小泽玛利亚', 'actor04': '波多野结衣', 'actor': '苍井空'}
>>> 'actor01' in info
True>>> info.get('avtor03')
'小泽玛利亚'>>> info['avtor03']
'小泽玛利亚'>>> info['actor06']
Traceback (most recent call last):
File "<pyshell#10>", line 1, in <module>
info['actor06']
KeyError: 'actor06'
删除
>>> info
{'actor01': '武藤兰', 'actor02': '泷泽萝拉', 'avtor03': '小泽玛利亚', 'actor04': '波多野结衣', 'actor': '苍井空'}
>>> info.pop('actor')
'苍井空'
>>> info
{'actor01': '武藤兰', 'actor02': '泷泽萝拉', 'avtor03': '小泽玛利亚', 'actor04': '波多野结衣'}>>> del info['actor01']
>>> info
{'actor02': '泷泽萝拉', 'avtor03': '小泽玛利亚', 'actor04': '波多野结衣'}>>> info.popitem() 随机删除
('actor04', '波多野结衣')
>>> info
{'actor02': '泷泽萝拉', 'avtor03': '小泽玛利亚'}
多级字典嵌套及操作
av_catalog = { "欧美":{ "www.youporn.com": ["很多免费的,世界最大的","质量一般"], "www.pornhub.com": ["很多免费的,也很大","质量比yourporn高点"], "letmedothistoyou.com": ["多是自拍,高质量图片很多","资源不多,更新慢"], "x-art.com":["质量很高,真的很高","全部收费,穷孩子请绕过"] }, "日韩":{ "tokyo-hot":["质量怎样不清楚,个人已经不喜欢日韩范了","听说是收费的"] }, "大陆":{ "1024":["全部免费,真好,好人一生平安","服务器在国外,慢"] } } av_catalog["大陆"]["1024"][1] += ",可以用爬虫" print(av_catalog["大陆"]["1024"]) #ouput ['全部免费,真好,好人一生平安', '服务器在国外,慢,可以用爬虫']
其他
>>> info.values()
dict_values(['泷泽萝拉', '小泽玛利亚'])>>> info.keys()
dict_keys(['actor02', 'avtor03'])>>> info.setdefault('actor07','ykyk')
'ykyk'
>>> info
{'actor02': '泷泽萝拉', 'avtor03': '小泽玛利亚', 'actor07': 'ykyk'}>>> info.setdefault('actor02','longzeluola')
'泷泽萝拉'
>>> info
{'actor02': '泷泽萝拉', 'avtor03': '小泽玛利亚', 'actor07': 'ykyk'
>>> a={1:2,3:4,'actor09':'苍井空'}
>>> info.update(a)
>>> info
{'actor02': '泷泽萝拉', 'avtor03': '小泽玛利亚', 'actor07': 'ykyk', 1: 2, 3: 4, 'actor09': '苍井空'}
>>> info.items()
dict_items([('actor02', '泷泽萝拉'), ('avtor03', '小泽玛利亚'), ('actor07', 'ykyk'), (1, 2), (3, 4), ('actor09', '苍井空')])
循环dict
方法1for key in info: print(key,info[key]) 方法2 for k,v in info.items(): #会先把dict转成list,数据量大时不要用 print(k,v)
集合操作
集合是一个无序的,不重复的数据组合
作用
去重,将一个列表变成一个集合,自动去重
关系测试,测试两组数据之间的交际、差集、并集等关系
常用操作
s = set([3,5,9,10]) #创建一个数值集合 t = set("Hello") #创建一个唯一字符的集合 a = t | s # t 和 s的并集 b = t & s # t 和 s的交集 c = t – s # 求差集(项在t中,但不在s中) d = t ^ s # 对称差集(项在t或s中,但不会同时出现在二者中) 基本操作: t.add('x') # 添加一项 s.update([10,37,42]) # 在s中添加多项 使用remove()可以删除一项: t.remove('H') len(s) set 的长度 x in s 测试 x 是否是 s 的成员 x not in s 测试 x 是否不是 s 的成员 s.issubset(t) s <= t 测试是否 s 中的每一个元素都在 t 中 s.issuperset(t) s >= t 测试是否 t 中的每一个元素都在 s 中 s.union(t) s | t 返回一个新的 set 包含 s 和 t 中的每一个元素 s.intersection(t) s & t 返回一个新的 set 包含 s 和 t 中的公共元素 s.difference(t) s - t 返回一个新的 set 包含 s 中有但是 t 中没有的元素 s.symmetric_difference(t) s ^ t 返回一个新的 set 包含 s 和 t 中不重复的元素 s.copy() 返回 set “s”的一个浅复制