美文网首页
集合容器(dict,set)

集合容器(dict,set)

作者: 流光汐舞 | 来源:发表于2017-07-15 15:29 被阅读0次

dict用法:

Python内置了字典:dict的支持,dict全称dictionary,在其他语言中也称为map,使用键-值(key-value)存储,具有极快的查找速度。

字典定义:

字典 = {key1 : value1, key2 : value2 ......}

键必须是唯一的,但值则不必。
值可以取任何数据类型,如字符串,数字或元组。
dict内部存放的顺序和key放入的顺序是没有关系的。
要保证hash的正确性,作为key的对象就不能变。
在Python中,字符串、整数等都是不可变的
因此,可以放心地作为key。而list是可变的,就不能作为key.

dict增/改:

字典[键] = 值
如果次key不存在,就是往字典里新增一个键值对;否则,就是修改
由于一个key只能对应一个value,所以,多次对一个key放入value,后面的值会把前面的值冲掉.

dict删:

1、字典.pop(键)    根据键,删除指定的值,并将此值放回

2、del 字典[键]    根据键,删除指定的值

3、字典.clear()    清空字典里的键值对

dict查询:

1、值 = 字典[键]      根据键查询值

2、字典.get(键,[默认值])  通过dict提供的get方法,如果key不存在,可以返回None,或者自己指定的value

3、len(字典)            计算字典元素个数,即键的总数。

4、str(字典)            输出字典可打印的字符串表示。 
    
5、dict.keys()          以列表返回一个字典所有的键    

6、dict.values()      以列表返回一个字典所有的值
 
7、dict.items()        以列表返回可遍历的(键, 值) 元组数组

dict判断:

键 in 字典      如果键在字典中存在,返回True,否则,返回False

dict的三种遍历方法:

1、for key in dict:
    print('%s:%s'%(key,dict[key]))

2、for key in dict.keys():
    print('%s:%s'%(key,dict[key]))

3、for k,v in dict.items():
    print('%s:%s'%(k,v)

dic的t其他一些用法:

1、dict.copy()        返回一个新的字典,内容一样,地址不同

2、dict.fromkeys(seq[, val]))
创建一个新字典,以序列 seq 中元素做字典的键,val 为字典所有键对应的初始值

3、dict.setdefault(key, default=None)
  和get()类似, 但如果键不存在于字典中,将会添加键并将值设为default
如果键在字典中,返回这个键所对应的值。
如果键不在字典中,向字典中插入这个键,并且以default为这个键的值,并返回 default(默认None)。

4、dict.update(dict2)    把字典dict2的键/值对更新到dict里

和list对比,dict有以下几个特点:
1、查找速度极快,不会随着key的增加而变慢;
2、需要占用大量的内存,内存浪费多。

而list:
1、查找和插入的时间随着元素的增加而增加;
2、占用空间小,浪费内存很少。

所以,dict是用空间来换取时间的一种方法。

set用法:

set是一个无序,不能重复的集合容器,所以可以用来过滤重复元素。

1、add(obj)  新增
2、remove(obj)   移除
3、|     并集
4、&     交集
5、-     差集

用法总结:

1、set.update(x)       将集合 x 并入原集合s中,x 还可以是列表,
                      元组,字典等,x 可以有多个,用逗号分开

2、set.discard( x )    将 x 从集合s中移除

3、pop()                 随机删除并返回集合s中某个值

4、clear()             清空

5、x in s              set同样支持in操作
 
6、union( x ) /&      返回s与集合x的交集,不改变原集合s,x 也可以是列表,元组,字典

7、intersection( x )     返回s与集合x的并集,不改变s, x 也可以是列表,元组,字典

8、difference( x )      返回在集合s中而不在集合 x 中的元素的集合,
                       不改变集合s, x 也可以是列表,元组,字典。

9、symmetric_difference( x )   返回s和集合x的对称差集,即只在其中一个集合中出现的元素,
                              不改变集合s, x 也可以是列表,元组,字典。

10、issubsetssss)        判断 集合s 是否是 集合x 子集

11、issuperset( x )     判断 集合x 是否是集合s的子集

相关文章

网友评论

      本文标题:集合容器(dict,set)

      本文链接:https://www.haomeiwen.com/subject/jnzahxtx.html