有没有一种优雅的方法可以通过迭代循环遍历列表 N 次(如 itertools.cycle 但限制循环)?

Is there an elegant way to cycle through a list N times via iteration (like itertools.cycle but limit the cycles)?(有没有一种优雅的方法可以通过迭代循环遍历列表 N 次(如 itertools.cycle 但限制循环)?)
本文介绍了有没有一种优雅的方法可以通过迭代循环遍历列表 N 次(如 itertools.cycle 但限制循环)?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

问题描述

我想通过一个迭代器反复(N 次)循环遍历一个列表,以免在内存中实际存储 N 个列表副本.有没有一种内置的或优雅的方法可以在不编写我自己的生成器的情况下做到这一点?

I'd like to cycle through a list repeatedly (N times) via an iterator, so as not to actually store N copies of the list in memory. Is there a built-in or elegant way to do this without writing my own generator?

理想情况下, itertools.cycle(my_list) 会有第二个参数来限制它循环的次数......唉,没有这样的运气.

Ideally, itertools.cycle(my_list) would have a second argument to limit how many times it cycles... alas, no such luck.

推荐答案

import itertools
itertools.chain.from_iterable(itertools.repeat([1, 2, 3], 5))

Itertools 是一个很棒的库.:)

Itertools is a wonderful library. :)

这篇关于有没有一种优雅的方法可以通过迭代循环遍历列表 N 次(如 itertools.cycle 但限制循环)?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

本站部分内容来源互联网,如果有图片或者内容侵犯了您的权益,请联系我们,我们会在确认后第一时间进行删除!

相关文档推荐

groupby multiple coords along a single dimension in xarray(在xarray中按单个维度的多个坐标分组)
Group by and Sum in Pandas without losing columns(Pandas中的GROUP BY AND SUM不丢失列)
Is there a way of group by month in Pandas starting at specific day number?( pandas 有从特定日期开始的按月分组的方式吗?)
Group by + New Column + Grab value former row based on conditionals(GROUP BY+新列+基于条件的前一行抓取值)
Groupby and interpolate in Pandas(PANDA中的Groupby算法和插值算法)
Pandas - Group Rows based on a column and replace NaN with non-null values(PANAS-基于列对行进行分组,并将NaN替换为非空值)