1.dict全称dictionary
d={‘miky’:95,‘lisa’:88,‘john’:89}
‘’’
print(d[‘lisa’])
print(d[‘john’])
‘’’
除了初始化时指定外,还可以通过key放入:由于一个key只能对应一个value,所以,多次对一个key放入value,后面的值会把前面的值冲掉:
d[‘bob’]=76
print(d[‘bob’])
‘’’
如果key不存在,dict就会报错:
>>> d['Thomas']
Traceback (most recent call last):
File “”, line 1, in
KeyError: ‘Thomas’
要避免key不存在的错误,有两种办法,一是通过in判断key是否存在:
>>> 'Thomas' in d
False
二是通过dict提供的get()方法,如果key不存在,可以返回None,或者自己指定的value:
>>> d.get('Thomas')
>>> d.get('Thomas', -1)
-1
和list比较,dict有以下几个特点:
查找和插入的速度极快,不会随着key的增加而变慢;
需要占用大量的内存,内存浪费多。
而list相反:
查找和插入的时间随着元素的增加而增加;
占用空间小,浪费内存很少。
所以,dict是用空间来换取时间的一种方法。
2.set
set和dict类似,也是一组key的集合,但不存储value。由于key不能重复,所以,在set中,没有重复的key。
s=set([1,2,2,2,3,3,3])
print(s)
{1, 2, 3}
通过add(key)方法可以添加元素到set中,可以重复添加,但不会有效果:
s.add(4)
print(s)
{1, 2, 3,4}
通过remove(key)方法可以删除元素:
s.remove(2)
print(s)
{1, 3, 4}
set可以看成数学意义上的无序和无重复元素的集合,因此,两个set可以做数学意义上的交集、并集等操作:
q=set([2,3,5,5,6,7])
print(s&q)
print(s|q)
{2, 3}
{1, 2, 3, 5, 6, 7}