Python 里的 dict
(字典)和 set
(集合)是非常常用的数据结构。它们不仅高效,而且语法也不复杂,是你写出优雅 Python 代码的必经之路。
它们是 Python 的王牌数据结构之一,掌握它们,你的代码会更简洁更高效。
参考文章: Python 使用 Dict 和 Set | 简单一点学习
一、基础入门:搞懂 dict 和 set 是啥
1.1 什么是 dict(字典)?
字典是"键-值"对的集合,键是唯一的,值可以是任意对象。
python
person = {
"name": "小明",
"age": 18,
"city": "北京"
}
字典的特点:
- 键必须是不可变类型(通常是字符串、数字、元组)
- 查找速度快,效率高
- 无序(从 Python 3.7 开始,插入顺序会被保留)
1.2 什么是 set(集合)?
集合是一个无序、无重复元素的集合体。
python
fruits = {"apple", "banana", "orange"}
集合的特点:
- 元素唯一,自动去重
- 可用于集合运算(交集、并集、差集等)
- 也是无序的,不能通过索引访问
二、常见操作:增删改查那点事
2.1 字典 dict 的基本操作
python
person = {"name": "小明", "age": 18}
# 查
print(person["name"]) # 小明
print(person.get("gender")) # None,不会报错
# 增
person["gender"] = "male"
# 改
person["age"] = 20
# 删
del person["gender"]
person.pop("age") # 返回值是被删掉的值
# 遍历
for key, value in person.items():
print(key, value)
2.2 集合 set 的基本操作
python
fruits = {"apple", "banana"}
# 查(不能用索引,只能遍历)
for fruit in fruits:
print(fruit)
# 增
fruits.add("orange")
# 删
fruits.remove("banana") # 如果没有这个元素会报错
fruits.discard("peach") # 不报错
# 清空
fruits.clear()
三、进阶用法:操作集合和字典的骚技巧
3.1 字典推导式
快速构建字典的方式:
python
squares = {x: x * x for x in range(5)}
# {0: 0, 1: 1, 2: 4, 3: 9, 4: 16}
3.2 集合推导式
python
unique_even = {x for x in range(10) if x % 2 == 0}
# {0, 2, 4, 6, 8}
3.3 字典常用方法
python
person.keys() # 所有键
person.values() # 所有值
person.items() # 所有键值对
person.update({"job": "engineer"}) # 批量更新
3.4 集合运算
python
a = {1, 2, 3}
b = {2, 3, 4}
print(a | b) # 并集 {1, 2, 3, 4}
print(a & b) # 交集 {2, 3}
print(a - b) # 差集 {1}
print(a ^ b) # 对称差集 {1, 4}
四、高级进阶:骚操作和性能优化
4.1 用 set 做去重
python
nums = [1, 2, 2, 3, 4, 4]
unique = list(set(nums)) # 去重后转回列表
4.2 用 dict 做计数器(不推荐手写,推荐用 Counter)
python
words = ["apple", "banana", "apple"]
counter = {}
for word in words:
counter[word] = counter.get(word, 0) + 1
或者用标准库里的:
python
from collections import Counter
counter = Counter(words)
4.3 用 dict 模拟 switch-case 语句
python
def add(): print("加法")
def sub(): print("减法")
func_map = {
"add": add,
"sub": sub
}
func_map.get("add", lambda: print("无操作"))()
4.4 用 frozenset 当字典键
因为普通 set 不可哈希,不能作为字典键,但 frozenset 可以:
python
d = {}
key = frozenset([1, 2, 3])
d[key] = "这是一个键"
五、总结一下
对象 | 特性 | 主要应用场景 |
---|---|---|
dict | 键值对存储,查找快 | 结构化数据,映射、缓存 |
set | 无重复元素,集合运算 | 去重、成员判断、数学集合 |