Python常用迭代器操作图解

  • map() 将一个函数应用于可迭代对象的每个元素,并返回结果列表。
  • filter() 使用指定的函数过滤可迭代对象的元素,并返回满足条件的元素组成的迭代器。
  • enumerate() 返回一个由索引和元素组成的元组的迭代器,常用于同时遍历索引和元素。
  • zip() 将多个可迭代对象的对应元素打包成元组的迭代器。
  • itertools.zip_longest()zip() 类似,但在处理不等长的可迭代对象时,会使用填充值填充缺失的元素。
  • itertools.tee() 复制可迭代对象的内容,生成两个相互独立的迭代器。
  • itertools.groupby() 用于对可迭代对象进行分组。它会返回一个由分组键和对应的迭代器组成的迭代器。

map()

scss 复制代码
li = [1, 2, 3]

# mapped_li 是一个 map object(Iterable) 而不是list
mapped_li = map(lambda x: str(x), li) 

# 若要变为list,则需要转换
mapped_list_li = list(mapped_li) # ['1', '2', '3']

# map操作可用生成器表达式代替,更清晰
mapped_li = [str(x) for x in li] # ['1', '2', '3']

filter()

ini 复制代码
li = [1, 2, 3]

# filtered_li 是一个 filter object(Iterable) 而不是list
filtered_li = filter(lambda x: x == 1, li) 

# 若要变为list,则需要转换
filtered_list_li = list(filtered_li) # [1]

# filter操作可用生成器表达式代替,更清晰
filtered_li = [x for x in li if x == 1] # [1]

enumerate()

css 复制代码
li = [5, 2, 0]

for i, x in enumerate(li):
 print(i, x)

# 0 5
# 1 2
# 2 0

enumerate([5, 2, 0]) 可以理解为 ((0, 5), (1, 2), (2, 0)) ,即 ((index, value), ...) 不过实际上这并不是一个元组,而是一个 enumerate object

zip()

ini 复制代码
li1 = [1, 2, 3]
li2 = [4, 5, 6]
li3 = [7, 8, 9]

zipped_li = zip(li1, li2, li3) # 同理,并不是list,而是zip object
zipped_list_li = list(zipped_li) # [(1, 4, 7), (2, 5, 8), (3, 6, 9)]

for x, y, z in zip(li1, li2, li3):
 ...
 
# 举例
students = ['小左', '小瑞', '小海']
schools = ['清华', '北大', '复旦']
homes = ['小左家', '小瑞家', '小海家']

for stu, school, home in zip(students, schools, homes):
 print(f'{stu}是{school}的学生,他在{home}')
 
# 小左是清华的学生,他在小左家
# 小瑞是北大的学生,他在小瑞家
# 小海是复旦的学生,他在小海家

itertools.zip_longest()

ini 复制代码
from itertools import zip_longest

li1 = [1, 2, 3]
li2 = [5, 6]
li3 = [9]

# 同理,并不是list,而是zip_longest object
zipped_li = zip_longest(li1, li2, li3, fillvalue=0) 
zipped_list_li = list(zipped_li) # [(1, 5, 9), (2, 6, 0), (3, 0, 0)]

itertools.tee()

ini 复制代码
from itertools import tee

li = [1, 2, 3]

li1, li2 = tee(li)

list_li1 = list(li1) # [1, 2, 3]
list_li2 = list(li2) # [1, 2, 3]

itertools.groupby()

less 复制代码
from itertools import groupby

data = [('A', 1), ('A', 2), ('B', 3), ('B', 4), ('B', 5)]

for key, group in groupby(data, key=lambda x: x[0]):
    print(key, list(group))

# A [('A', 1), ('A', 2)]
# B [('B', 3), ('B', 4), ('B', 5)]
相关推荐
代码的乐趣16 分钟前
支持selenium的chrome driver更新到131.0.6778.204
chrome·python·selenium
又蓝41 分钟前
使用 Python 操作 Excel 表格
开发语言·python·excel
余~~185381628001 小时前
稳定的碰一碰发视频、碰一碰矩阵源码技术开发,支持OEM
开发语言·人工智能·python·音视频
0zxm1 小时前
06 - Django 视图view
网络·后端·python·django
m0_748257181 小时前
Spring Boot FileUpLoad and Interceptor(文件上传和拦截器,Web入门知识)
前端·spring boot·后端
ROBOT玲玉2 小时前
Milvus 中,FieldSchema 的 dim 参数和索引参数中的 “nlist“ 的区别
python·机器学习·numpy
小_太_阳2 小时前
Scala_【1】概述
开发语言·后端·scala·intellij-idea
智慧老师2 小时前
Spring基础分析13-Spring Security框架
java·后端·spring
Kai HVZ3 小时前
python爬虫----爬取视频实战
爬虫·python·音视频
古希腊掌管学习的神3 小时前
[LeetCode-Python版]相向双指针——611. 有效三角形的个数
开发语言·python·leetcode