Python基础 -- Task06. 字典与集合

Python 基础语法

1. 字典

序列是以连续的整数为索引,与此不同的是,字典以"关键字"为索引,关键字可以是任意不可变类型,通常用字符串或数值。
字典是 Python 唯一的一个 映射类型,字符串、元组、列表属于序列类型。
那么如何快速判断一个数据类型 X 是不是可变类型的呢?两种方法:

麻烦方法:用 id(X) 函数,对 X 进行某种操作,比较操作前后的 id,如果不一样,则 X 不可变,如果一样,则 X 可变。
便捷方法:用 hash(X),只要不报错,证明 X 可被哈希,即不可变,反过来不可被哈希,即可变。
Python基础 -- Task06. 字典与集合
整数 i 在加 2 之后的 id 和之前不一样,因此加完之后的这个 i (虽然名字没变),但是不是加前的那个 i 了,因此整数是不可更改的。
列表 l 在附加 ‘happy’’ 之后的 id 和之前一样,因此列表是可更改的。
Python基础 -- Task06. 字典与集合
字符和元组 都能被哈希,因此它们是不可更改的。列表不能被哈希,因此它是可更改的。
「字典」定义语法为 {元素1, 元素2, …, 元素n}
其中每一个元素是一个「键值对」- 键:值 (key:value)
关键点是「大括号 {}」,「逗号 ,」和「冒号 :」
大括号 把所有元素绑在一起
逗号 将每个键值对一一分开
冒号 将键和值分开

创建和访问字典

字典是无序的 键:值对(key:value 对)集合,键必须是互不相同的(在同一个字典之内)。
Python基础 -- Task06. 字典与集合
dict(object) 函数用于创建一个字典。
dict() -> new empty dictionary
dict(mapping) -> new dictionary initialized from a mapping object’s (key, value) pairs
dict(iterable) -> new dictionary initialized as if via:
Python基础 -- Task06. 字典与集合
dict(**kwargs) -> new dictionary initialized with the name=value pairs in the keyword argument list. For example:
Python基础 -- Task06. 字典与集合
dict 内部存放的顺序和 key 放入的顺序是没有关系的。
dict 查找和插入的速度极快,不会随着 key 的增加而增加,但是需要占用大量的内存。
把数据放入 dict 还可以直接通过 key 放入。
一个 key 只能对应一个 value,多次对一个 key 放入 value,后面的值会把前面的值冲掉。
Python基础 -- Task06. 字典与集合

字典的内置方法

dict.fromkeys(seq[, value]) 用于创建一个新字典,以序列 seq 中元素做字典的键,value 为字典所有键对应的初始值。
dict.keys()返回一个可迭代对象,可以使用 list() 来转换为列表。
dict.values()返回一个迭代器,可以使用 list() 来转换为列表,列表为字典中的所有值。
dict.items()以列表返回可遍历的(键, 值) 元组数组。

Python基础 -- Task06. 字典与集合
dict.get(key, default=None)返回指定键的值,如果值不在字典中返回默认值。

Python基础 -- Task06. 字典与集合
key in dict in 操作符用于判断键是否存在于字典中,如果键在字典 dict 里返回true,否则返回false。而not in操作符刚好相反,如果键在字典 dict 里返回false,否则返回true。
Python基础 -- Task06. 字典与集合
dict.clear()用于删除字典内所有元素。
dict.copy()返回一个字典的浅复制。
Sample:直接赋值和 copy 的区别
Python基础 -- Task06. 字典与集合
dict.pop(key[,default])删除字典给定键 key 所对应的值,返回值为被删除的值。key 值必须给出。否则,返回 default 值。
del dict[key] 删除字典给定键 key 所对应的值。
dict.popitem()随机返回并删除字典中的一对键和值,如果字典已经为空,却调用了此方法,就报出KeyError异常。
Python基础 -- Task06. 字典与集合
dict.setdefault(key, default=None)和get()方法 类似, 如果键不存在于字典中,将会添加键并将值设为默认值。
dict.update(dict2)把字典参数 dict2 的 key/value(键/值) 对更新到字典 dict 里。
Python基础 -- Task06. 字典与集合

2. 集合

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

集合的创建

直接把一堆元素用花括号括起来{元素1, 元素2, …, 元素n},重复元素在set中会被自动被过滤。
Python基础 -- Task06. 字典与集合
使用set(value)工厂函数,把列表或元组转换成集合。
Python基础 -- Task06. 字典与集合
Python基础 -- Task06. 字典与集合
去掉列表中重复的元素
Python基础 -- Task06. 字典与集合
Python基础 -- Task06. 字典与集合
从结果发现集合的两个特点:无序 (unordered) 和唯一 (unique)。由于 set 存储的是无序集合,所以我们没法通过索引来访问,但是可以判断一个元素是否在集合中。

访问集合中的值

可以使用for把集合中的数据一个个读取出来。
可以通过in或not in判断一个元素是否在集合中已经存在
Python基础 -- Task06. 字典与集合

集合的内置方法

set.add(elmnt)用于给集合添加元素,如果添加的元素在集合中已存在,则不执行任何操作。
set.remove(item)用于移除集合中的指定元素。
set.update(set)用于修改当前集合,可以添加新的元素或集合到当前集合中,如果添加的元素在集合中已存在,则该元素只会出现一次,重复的会忽略。
Python基础 -- Task06. 字典与集合
由于 set 是无序和无重复元素的集合,所以两个或多个 set 可以做数学意义上的集合操作。
set.intersection(set1, set2 …)用于返回两个或更多集合中都包含的元素,即交集。
set.union(set1, set2…)返回两个集合的并集,即包含了所有集合的元素,重复的元素只会出现一次。
set.difference(set) 返回集合的差集,即返回的集合元素包含在第一个集合中,但不包含在第二个集合(方法的参数)中。Python基础 -- Task06. 字典与集合
set.issubset(set)用于判断集合的所有元素是否都包含在指定集合中,如果是则返回 True,否则返回 False。
set.issuperset(set)用于判断指定集合的所有元素是否都包含在原始的集合中,如果是则返回 True,否则返回 False。
Python基础 -- Task06. 字典与集合

3. 不可变集合

frozenset([iterable]) 返回一个冻结的集合,冻结后集合不能再添加或删除任何元素。
Python基础 -- Task06. 字典与集合