python学习(6)dict字典和set

来源:互联网 发布:无间道1的知乎 编辑:程序博客网 时间:2024/05/17 15:38

    • dict字典
      • 定义方法
      • 注意事项
      • 一些操作
      • 和list比较dict有以下几个特点
    • set
      • 一些操作
    • 总结

dict字典

Python内置了字典:dict的支持,dict全称dictionary,在其他语言中也称为map,使用键-值(key-value)存储,具有极快的查找速度。

定义方法

d = {‘Michael’: 95, ‘Bob’: 75, ‘Tracy’: 85}

注意事项

key-value存储方式,在放进去的时候,根据key算出value的存放位置(不需要人来算),这样,取的时候才能根据key直接拿到value。
(所以内部数据除了一一对应以外其实是无序的)
通过key计算位置的算法称为哈希算法(Hash)

由于位置是由key值决定的,所以key值不可变化

一些操作

根据key查value d[‘Thomas’]
**删除操作**pop(key)
判断key值是否在相应字典中

>>> ‘Thomas’ in d
False

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

>>> d.get(‘Thomas’)
>>> d.get(‘Thomas’, -1)
-1

注意:返回None的时候Python的交互式命令行不显示结果。

和list比较,dict有以下几个特点:

查找和插入的速度极快,不会随着key的增加而变慢;
需要占用大量的内存,内存浪费多。
而list相反:

查找和插入的时间随着元素的增加而增加;
占用空间小,浪费内存很少。
所以,dict是用空间来换取时间的一种方法。

set

set和dict类似,也是一组key的集合,但不存储value。由于key不能重复,所以,在set中,没有重复的key。(重复元素自动整合)
(dict里就有重复的key了???)

一些操作

增加操作add(key)(可以重复添加,但不会有效果)
删除操作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里边是放不了list了

总结

基础篇到这就结束了,都是很基础很简单的,记清楚就好了

原创粉丝点击