Python学习总结----基础篇5

字典操作

字典是一种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

方法1
for 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”的一个浅复制  

转载于:https://www.cnblogs.com/ykyk1229/p/8525930.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值