python 的内置字典

python内置了字典:dict(key-value存储方式)的支持,dict全称dictionary,在其他语言中也称为map,使用键-值(key-value)存储,具有极快的查找速度。>>>d={'Michael':95,'Bob':75,'Tracy':85}

把数据放入dict的方法,除了初始化时指定外,还可以通过key放入(多次对一个key放入value,后面的值会把前面的值冲掉):>>>d['Adam']=67

>>>d['Adam']67

要避免key不存在的错误,有两种办法,一是通过in判断key是否存在:>>>'Thomas'ind

False

二是通过dict提供的get()方法,如果key不存在,可以返回None,或者自己指定的value:

>>>d.get('Thomas')#注意:返回None的时候Python的交互环境不显示结果。

>>>d.get('Thomas',-1)-1

要删除一个key,用pop(key)方法,对应的value也会从dict中删除:>>>d.pop('Bob')75

>>>d

{'Michael':95,'Tracy':85}

请务必注意,dict内部存放的顺序和key放入的顺序是没有关系的。dict是用空间来换取时间的一种方法。

dict的key必须是不可变对象。在Python中,字符串、整数等都是不可变的,因此,可以放心地作为key。而list是可变的,就不能作为key。

set和dict类似,也是一组key的集合,但不存储value。由于key不能重复,所以,在set中,没有重复的key。

要创建一个set,需要提供一个list作为输入集合:

>>>s=set([1,2,3])

>>>s

{1,2,3}

注意,传入的参数[1,2,3]是一个list,而显示的{1,2,3}只是告诉你这个set内部有1,2,3这3个元素,显示的顺序也不表示set是有序的。

重复元素在set中自动被过滤:

>>>s=set([1,1,2,2,3,3])

>>>s

{1,2,3}

通过add(key)方法可以添加元素到set中,可以重复添加,但不会有效果。

通过remove(key)方法可以删除元素。

set可以看成数学意义上的无序和无重复元素的集合,因此,两个set可以做数学意义上的交集、并集等操作:

>>>s1=set([1,2,3])

>>>s2=set([2,3,4])

>>>s1&s2

{2,3}

>>>s1|s2

{1,2,3,4}

注意:

set和dict的唯一区别仅在于没有存储对应的value,但是,set的原理和dict一样,所以,同样不可以放入可变对象,因为无法判断两个可变对象是否相等,也就无法保证set内部“不会有重复元素”。

>>>classmates=['Michael','Bob','Tracy']#list用[]定义

>>>classmates=('Michael','Bob','Tracy')#tuple用()定义

>>>d={'Michael':95,'Bob':75,'Tracy':85}#dic用{}来定义

>>>s=set([1,2,3])#set用()来定义

以上内容为大家介绍了Python增强,希望对大家有所帮助,如果想要了解更多Python相关知识,请关注我们

推荐阅读