python 的内置字典

发布时间:2022-05-13 09:42:34 人气:17 作者:多测师

  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' in d

  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。

python 的内置字典

  要创建一个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相关知识,请关注多测师。https://www.e70w.com/xwzx/


返回列表
在线客服
联系方式

热线电话

17727591462

上班时间

周一到周五

二维码
线