python itertools模块详解

简介

itertools,是python的一个内置模块,功能强大,主要用于高效循环创建迭代器。注意一点,他返回的不是list,而是iterator

无穷迭代器

count()

count(start, [step])会创建一个无限迭代器,从当前数字无限循环下去,停止可以按Ctrl+c键
在这里插入图片描述

cycle()

cycle( p)会把传入的序列无限的循环打印
在这里插入图片描述

repeat()

repeat(elem [,n])可以把一个元素无限循环
在这里插入图片描述
也可以添加第二个参数来限制个数
在这里插入图片描述

有限迭代器

因为有限迭代器有十多个,这里只列举几个常用的函数

chain()

chain(p,q…)可以把一组迭代对象串联起来,形成一个更大的迭代器
在这里插入图片描述

groupby()

groupby(iterable,key=None])把迭代器中相邻的元素按照key函数分组,当key=None时,把相邻的重复元素进行分组
在这里插入图片描述
在这里插入图片描述

accumulate()

accumulate(iterable [,func])是一个计算迭代器,如果不指定参数函数,将会采取默认的求和函数
在这里插入图片描述

也可以指定参数函数,比如求最大值
在这里插入图片描述
关于有限迭代器还有更多有趣的函数,可以去官方文档查看
itertools官方文档

组合迭代器

组合操作在算法中经常会用到,因此这里就体现出来itertools模块的便捷性
下面来看看四个组合迭代器的用法

product()

product(p,q,…[repeat=1])得到的是可迭代的笛卡尔积,多个可迭代对象的笛卡尔积可以通过for循环来实现,比如product(a,b)用for循环可以表示为

((i,j) for i in a for j in b)

在这里插入图片描述
函数中的repeat参数表示前面可迭代序列的重复次数
比如product(a, repeat=4) 就表示 product(a, a, a, a)

permutations()

permutations(p[, r])返回的是一个长度为 r 的所有可能排列,无重复元素
在这里插入图片描述
第二个参数默认为迭代序列长度

combinations()

combinations(p, r)返回的是一个长度为r的组合,它是有序的,无重复元素
在这里插入图片描述

combinations_with_replacement()

combinations_with_replacement(p, r)返回的是一个长度为r的组合,它是有序的,元素可以重复
在这里插入图片描述

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

不会写代码的嘤嘤

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值