问题描述
我有一个带有数字的列表:数字 = [1, 2, 3, 4].
I have a list with numbers:
numbers = [1, 2, 3, 4].
我想要一个列表,他们像这样重复 n 次(对于 n = 3):
I would like to have a list where they repeat n times like so (for n = 3):
[1, 1, 1, 2, 2, 2, 3, 3, 3, 4, 4, 4].
问题是我只想为此使用 itertools,因为我的性能非常有限.
The problem is that I would like to only use itertools for this, since I am very constrained in performance.
我尝试使用这个表达式:
I tried to use this expression:
list(itertools.chain.from_iterable(itertools.repeat(numbers, 3)))
但它给了我这样的结果:
But it gives me this kind of result:
[1, 2, 3, 4, 1, 2, 3, 4, 1, 2, 3, 4]
这显然不是我需要的.
有没有办法只使用 itertools 来做到这一点,而不使用排序、循环和列表推导?我能得到的最接近的是:
Is there a way to do this with itertools only, without using sorting, loops and list comprehensions? The closest I could get is:
list(itertools.chain.from_iterable([itertools.repeat(i, 3) for i in numbers])),
但它也使用列表理解,我想避免.
but it also uses list comprehension, which I would like to avoid.
推荐答案
由于不想使用列表推导式,下面是纯(+zip) itertools 方法——
Since you don't want to use list comprehension, following is a pure (+zip) itertools method to do it -
from itertools import chain, repeat
list(chain.from_iterable(zip(*repeat(numbers, 3))))
# [1, 1, 1, 2, 2, 2, 3, 3, 3, 4, 4, 4]
这篇关于如何仅使用 itertools 将 Python 列表的每个元素重复 n 次?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!


大气响应式网络建站服务公司织梦模板
高端大气html5设计公司网站源码
织梦dede网页模板下载素材销售下载站平台(带会员中心带筛选)
财税代理公司注册代理记账网站织梦模板(带手机端)
成人高考自考在职研究生教育机构网站源码(带手机端)
高端HTML5响应式企业集团通用类网站织梦模板(自适应手机端)