栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

在Python中按(n个)块迭代迭代器?

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

在Python中按(n个)块迭代迭代器?

grouper()

从配方
itertools
文件的食谱来靠近你想要什么:

def grouper(n, iterable, fillvalue=None):    "grouper(3, 'ABCDEFG', 'x') --> ABC DEF Gxx"    args = [iter(iterable)] * n    return izip_longest(fillvalue=fillvalue, *args)

但是,它将使用填充值填充最后一个块。

较不通用的解决方案仅适用于序列,但可以根据需要处理最后一个块

[my_list[i:i + chunk_size] for i in range(0, len(my_list), chunk_size)]

最后,一种可在一般迭代器上运行且其行为符合预期的解决方案是

def grouper(n, iterable):    it = iter(iterable)    while True:       chunk = tuple(itertools.islice(it, n))       if not chunk:return       yield chunk


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/617397.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号