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相关知识,请关注IT培训机构:开发教育。
鹏仔微信 15129739599 鹏仔QQ344225443 鹏仔前端 pjxi.com 共享博客 sharedbk.com
图片声明:本站部分配图来自网络。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!