字典

  1. 可变类型与不可变类型
    序列是以连续的整数为索引,与此不同的是,字典以"关键字"为索引,关键字可以是任意不可变类型,通常用字符串或数值。
    字典是 Python 唯一的一个 映射类型,字符串、元组、列表属于序列类型。
  2. 字典的定义
    字典 是无序的 键:值(key:value)对集合,键必须是互不相同的(在同一个字典之内)。

dict 内部存放的顺序和 key 放入的顺序是没有关系的。
dict 查找和插入的速度极快,不会随着 key 的增加而增加,但是需要占用大量的内存。
3. 创建和访问字典
4. 字典的内置方法
dict.fromkeys(seq[, value]) 用于创建一个新字典,以序列 seq 中元素做字典的键,value 为字典所有键对应的初始值。

集合

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

注意,key为不可变类型,即可哈希的值。

  1. 集合的创建
    先创建对象再加入元素。
    在创建空集合的时候只能使用s = set(),因为s = {}创建的是空字典。
  2. 访问集合中的值
  3. 集合的内置方法
    set.add(elmnt)用于给集合添加元素,如果添加的元素在集合中已存在,则不执行任何操作。
    set.update(set)用于修改当前集合,可以添加新的元素或集合到当前集合中,如果添加的元素在集合中已存在,则该元素只会出现一次,重复的会忽略。
    set.difference(set) 返回集合的差集。
    set1 - set2 返回集合的差集。
    set.difference_update(set) 集合的差集,直接在原来的集合中移除元素,没有返回值。
  4. 集合的转换
  5. 不可变集合
    Python 提供了不能改变元素的集合的实现版本,即不能增加或删除元素,类型名叫frozenset。需要注意的是frozenset仍然可以进行集合操作,只是不能用带有update的方法。

序列

在 Python 中,序列类型包括字符串、列表、元组、集合和字典,这些序列支持一些通用的操作,但比较特殊的是,集合和字典不支持索引、切片、相加和相乘操作。

  1. 针对序列的内置函数
    sorted(iterable, key=None, reverse=False) 对所有可迭代的对象进行排序操作。
    iterable – 可迭代对象。
    key – 主要是用来进行比较的元素,只有一个参数,具体的函数的参数就是取自于可迭代对象中,指定可迭代对象中的一个元素来进行排序。
    reverse – 排序规则,reverse = True 降序 , reverse = False 升序(默认)。
    返回重新排序的列表。
    reversed(seq) 函数返回一个反转的迭代器。
    seq – 要转换的序列,可以是 tuple, string, list 或 range
enumerate(sequence, [start=0])
zip(iter1 [,iter2 [...]])

用于将可迭代的对象作为参数,将对象中对应的元素打包成一个个元组,然后返回由这些元组组成的对象,这样做的好处是节约了不少的内存。
我们可以使用 list() 转换来输出列表。
如果各个迭代器的元素个数不一致,则返回列表长度与最短的对象相同,利用 * 号操作符,可以将元组解压为列表。