还在手动写循环处理数据?Python 里这几个 "懒人神器",看似基础却能直接拉高代码效率,新手也能秒上手!
1. itertools :循环偷懒神器,少写 N 行重复代码
处理迭代器时,itertools 里的方法能帮你实现各种花式循环,不用再手写嵌套逻辑。最常用的就是 cycle(无限循环)和 chain(拼接迭代器)。
python
import itertools
# 需求1:循环遍历列表,到末尾后从头再来
colors = ["red", "green", "blue"]
color_cycle = itertools.cycle(colors)
# 取前5个元素(演示用,实际可无限取)
for _ in range(5):
print(next(color_cycle))
# 输出:red green blue red green
# 需求2:拼接多个列表,避免创建新列表占用内存
list1 = [1, 2, 3]
list2 = [4, 5, 6]
combined = itertools.chain(list1, list2)
for num in combined:
print(num, end=" ") # 输出:1 2 3 4 5 6
2. collections.defaultdict :字典分组不翻车,告别 KeyError
用普通字典分组时,得先判断键是否存在,而 defaultdict 能直接指定默认值类型,分组代码一步到位。
python
from collections import defaultdict
# 需求:把学生按成绩等级分组
students = [
("小明", "A"),
("小红", "B"),
("小刚", "A"),
("小美", "B")
]
# 传统字典写法:繁琐且易出错
grade_dict = {}
for name, grade in students:
if grade not in grade_dict:
grade_dict[grade] = []
grade_dict[grade].append(name)
print(grade_dict) # {'A': ['小明', '小刚'], 'B': ['小红', '小美']}
# defaultdict 写法:简洁高效
default_grade = defaultdict(list)
for name, grade in students:
default_grade[grade].append(name)
print(dict(default_grade)) # 结果同上
3. enumerate 进阶用法:自定义起始索引,循环更灵活
基础的 enumerate 大家都会用,但自定义起始索引这个小细节,能让循环结果更贴合实际需求,不用再手动 +1。
python
# 需求:打印学生排名,从1开始计数
names = ["张三", "李四", "王五"]
# 基础用法:默认从0开始
for idx, name in enumerate(names):
print(f"第{idx+1}名:{name}") # 手动+1,麻烦
# 进阶用法:指定start参数,直接从1开始
for idx, name in enumerate(names, start=1):
print(f"第{idx}名:{name}")
# 输出:
# 第1名:张三
# 第2名:李四
# 第3名:王五
小总结
itertools能简化迭代器操作,减少重复循环代码;defaultdict是字典分组的 "利器",避免手动判断键是否存在;enumerate指定start参数,能直接得到符合需求的索引。