在 Python 中列表list、元组tuple、字典dict和集合set都是可迭代对象Iterable遍历的核心机制是for...in循环但根据它们底层数据结构的差异序列、映射、哈希表遍历方式各有特色。下面我为你由浅入深地详细梳理并特别针对集合Set进行深度扩展。一、遍历列表List与元组Tuple列表和元组都是有序序列遍历方式完全通用元组不可变但遍历语法一致。1. 直接遍历元素最常用直接取出容器内的每个元素。lst[a,b,c]foriteminlst:print(item)# 输出: a, b, c2. 通过索引遍历range 长度适用于需要修改元素值或需要知道元素位置下标时。foriinrange(len(lst)):print(f索引{i}:{lst[i]})3. 同时获取索引和元素enumerate——Pythonic 推荐省去手动维护下标的麻烦效率高且优雅。forindex,valueinenumerate(lst):print(f第{index}个元素是{value})# 可以自定义起始序号forindex,valueinenumerate(lst,start1):print(f第{index}个元素是{value})4. 反向遍历reversed不修改原列表生成反向迭代器。foriteminreversed(lst):print(item)# 输出: c, b, a5. 并行遍历多个序列zip同时拉取多个列表的对应位置元素。names[A,B]scores[90,85]forname,scoreinzip(names,scores):print(f{name}:{score})6. 使用while循环通用但不推荐用于单纯遍历底层通过下标控制适合复杂退出条件但书写繁琐。i0whileilen(lst):print(lst[i])i1二、遍历字典Dict字典是键值对Key-Value映射结构Python 3.7 保证插入顺序。1. 直接遍历默认遍历键keys()d{name:Tom,age:18}forkeyind:print(key)# 输出: name, age# 等价于 for key in d.keys():2. 遍历值values()只关心数据不关心标签。forvalueind.values():print(value)# 输出: Tom, 183. 同时遍历键和值items()——最常用解包元组直接获取完整数据。forkey,valueind.items():print(f{key}-{value})4. 遍历字典时修改内容需转换为列表重点遍历过程中直接修改字典大小增删会报RuntimeError。解决办法是把视图转为列表再遍历。# 错误示范for k in d: del d[k] # 报错# 正确做法forkinlist(d.keys()):ifkage:deld[k]三、遍历集合Set—— 基础篇集合是无序严格说是有序但开发者不可依赖、元素唯一的哈希表。1. 标准for循环遍历元素s{1,2,3,a}foritemins:print(item)# 每次运行顺序可能不同如 a, 1, 2, 32. 使用enumerate获取人为序号由于集合无序“索引”在此处仅代表遍历到第几个元素不代表物理位置。foridx,iteminenumerate(s):print(f第{idx}个取出的元素是:{item})3. 使用迭代器iter和next底层实现通常用于手动精细控制。ititer(s)whileTrue:try:itemnext(it)print(item)exceptStopIteration:break4. 集合推导式Comprehension本质上也是一种遍历并生成新集合的语法糖。new_set{x*2forxinsifisinstance(x,int)}注意集合不支持索引访问如s[0]也不支持切片因此无法通过range(len(s))的方式按位置遍历。四、深入详解 Python 中的集合Set既然你要“详细介绍”我把集合从底层原理到实战细节彻底展开。1. 核心特性无序性基于哈希表Hash Table实现元素存放位置由哈希值决定不维护插入顺序虽然 CPython 3.6 后实现上保留了插入顺序但官方文档不保证请勿依赖。唯一性自动去重任何两个相等的元素只会保留一个。元素必须可哈希Hashable不可变类型int, str, tuple可以放入可变类型list, dict, set不能放入否则报TypeError: unhashable type。2. 创建集合的坑a{}# 这是空字典不是集合bset()# 这是正确的空集合c{1,2,3}# 非空集合3. 增删改查核心方法方法作用注意事项add(elem)添加元素如果已存在则无效果update(iterable)合并另一个可迭代对象批量加相当于 remove(elem)删除元素元素不存在会报错KeyErrordiscard(elem)删除元素元素不存在也不会报错推荐pop()随机弹出一个元素空集合调用会报错clear()清空集合-4. 集合数学运算高频考点这是集合相比其他数据结构最强大的功能性能极高基于哈希碰撞检测。运算操作符方法名含义并集|union()两者加起来的所有元素交集intersection()两者共有的元素差集-difference()在 A 但不在 B 中的元素对称差集^symmetric_difference()只属于其中一个集合的元素剔除共有子集/超集/issubset()/issuperset()判断包含关系是否不相交-isdisjoint()没有交集返回 TrueA{1,2,3}B{3,4,5}print(A-B)# {1, 2}print(AB)# {3}print(A^B)# {1, 2, 4, 5}5. 巨大的性能优势 —— 成员检测列表Listif x in list时间复杂度O(n)遍历查找。集合Setif x in set时间复杂度O(1)哈希直接命中。实战建议如果需要频繁判断某个元素是否存在务必先将列表转为集合再判断。6. 不可变集合 ——frozenset既然集合不能包含集合因为可变但业务上可能需要嵌套结构。frozenset是集合的不可变版本可以作为字典的键或另一个集合的元素。fsfrozenset([1,2,3])d{fs:value}# 合法7. 遍历集合时修改集合同样不安全和字典一样遍历中修改集合大小会报错。解决方案遍历其副本。s{1,2,3,4}foriteminlist(s):# 转换为列表副本ifitem%20:s.remove(item)print(s)# {1, 3}总结对比快速记忆数据结构遍历常用方式是否有序是否允许重复能否索引列表for item in listenumerate✅✅✅元组同上✅✅✅字典for k,v in dict.items()✅ (3.7)键唯一值随意按键名dict[key]集合for item in set❌ (不可依赖)❌ (自动去重)❌ (哈希表无序)最后送给你一条 Python 之禅“Flat is better than nested.”遍历时优先使用for...in直接解包少用range(len())代码会更具可读性。