基础知识----dict和set
dict
Python内置了字典:dict的支持,dict全称dictionary,在其他语言中也称为map,使用键-值(key-value)存储,具有极快的查找速度。如:d = {‘Michael’: 95, ‘Bob’: 75, ‘Tracy’: 85}
由于一个key只能对应一个value,所以,多次对一个key放入value,后面的值会把前面的值冲掉
如果key不存在,dict就会报错,要避免key不存在的错误,有两种办法:
一是通过in判断key是否存在
二是通过dict提供的get()方法,如果key不存在,可以返回None,或者自己指定的value
>>> 'Thomas' in d
False
print("########"*2) # 分界限
d = {'Michael': 95, 'Bob': 75, 'Tracy': 85}
a = d.get("Tom") # 运行结果为None
b = d.get("Tom", -100) # 没有对应的value,反回了指定的值“-100”
print(a, b)
要删除一个key,用**pop(key)**方法,对应的value也会从dict中删除。
使用key-value存储结构的dict在Python中非常有用,选择不可变对象作为key很重要,最常用的key是字符串。
list 和 dict 的区别
和list比较,dict有以下几个特点:
查找和插入的速度极快,不会随着key的增加而变慢;需要占用大量的内存,内存浪费多。
而list相反:
查找和插入的时间随着元素的增加而增加;占用空间小,浪费内存很少。
所以,dict是用空间来换取时间的一种方法。
set
set和dict类似,也是一组key的集合,但不存储value。由于key不能重复,所以,在set中,没有重复的key。重复元素在set中自动被过滤
通过**add(key)**方法可以添加单个元素到set中,可以重复添加,但不会有效果.
通过**update( key )**可以添加多个元素到set中,且参数可以是列表,元组,字典等
通过**remove(key)**方法可以删除元素.
set可以看成数学意义上的无序和无重复元素的集合,因此,两个set可以做数学意义上的交集、并集等操作。
对于集合,如果要创建一个空集合,不能使用s={}来创建空集合,因为这样创建的是一个dict。创建集合可以使用s={xx,xx,xx},也可以使用set([xx,xx,xx]),但创建空集合只能使用s=set()
set和dict的唯一区别仅在于没有存储对应的value,但是,set的原理和dict一样,所以,同样不可以放入可变对象,因为无法判断两个可变对象是否相等,也就无法保证set内部“不会有重复元素”。
s = set(("a"))
s.add(("m","d")) # add只能添加一个元素,这个元素可以是单个字符,也可以是包含多个字符的一个列表,元组,但不能是集合或者字典
s.update([1,3,6],{4,"k"}) #添加元素,且参数可以是列表,元组,字典等
print(s)