如何压缩两个不同大小的列表,重复较短的列表?
- 2025-01-15 08:45:00
- admin 原创
- 100
问题描述:
我想压缩两个不同长度的列表
例如
A = [1,2,3,4,5,6,7,8,9]
B = ["A","B","C"]
我希望如此
[(1, 'A'), (2, 'B'), (3, 'C'), (4, 'A'), (5, 'B'), (6, 'C'), (7, 'A'), (8, 'B'), (9, 'C')]
但是内置方法zip
不会重复与更大尺寸的列表配对。有没有什么内置方法可以实现这一点?
这是我的代码:
idx = 0
zip_list = []
for value in larger:
zip_list.append((value,smaller[idx]))
idx += 1
if idx == len(smaller):
idx = 0
解决方案 1:
您可以使用itertools.cycle
:
创建一个迭代器,返回可迭代对象的元素并保存每个元素的副本。当可迭代对象耗尽时,返回已保存副本中的元素。无限重复。
例子:
A = [1,2,3,4,5,6,7,8,9]
B = ["A","B","C"]
from itertools import cycle
zip_list = zip(A, cycle(B)) if len(A) > len(B) else zip(cycle(A), B)
解决方案 2:
针对任意数量的可迭代对象的解决方案,并且您不知道哪一个是最长的(也允许任何空的可迭代对象使用默认值):
from itertools import cycle, zip_longest
def zip_cycle(*iterables, empty_default=None):
cycles = [cycle(i) for i in iterables]
for _ in zip_longest(*iterables):
yield tuple(next(i, empty_default) for i in cycles)
for i in zip_cycle(range(2), range(5), ['a', 'b', 'c'], []):
print(i)
输出:
(0, 0, 'a', None)
(1, 1, 'b', None)
(0, 2, 'c', None)
(1, 3, 'a', None)
(0, 4, 'b', None)
解决方案 3:
尝试一下。
A = [1,2,3,4,5,6,7,8,9]
B = ["A","B","C"]
Z = []
for i, a in enumerate(A):
Z.append((a, B[i % len(B)]))
只需确保更大的列表在即可A
。
解决方案 4:
您知道第二份清单更短吗?
import itertools
list(zip(my_list, itertools.cycle(another_list)))
这实际上会给你一个元组列表,而不是列表的列表。我希望这样没问题。
解决方案 5:
您可以使用itertools.cycle
:
from itertools import cycle
my_list = [1, 2, 3, 5, 5, 9]
another_list = ['Yes', 'No']
cyc = cycle(another_list)
print([[i, next(cyc)] for i in my_list])
# [[1, 'Yes'], [2, 'No'], [3, 'Yes'], [5, 'No'], [5, 'Yes'], [9, 'No']]
解决方案 6:
一个非常简单的方法是将短列表乘以更长:
my_list = [1, 2, 3, 5, 5, 9]
another_list = ['Yes', 'No']
zip(my_list, another_list*3))
#[(1, 'Yes'), (2, 'No'), (3, 'Yes'), (5, 'No'), (5, 'Yes'), (9, 'No')]
请注意,乘数不需要仔细计算,因为zip
它只与最短列表的长度有关(乘数的目的是确保最短列表为)。也就是说,如果使用 而不是my_list
,结果将是相同的。100
`3`
解决方案 7:
对于可以以任意顺序处理任意有限数量的潜在无限可迭代对象的版本:
from itertools import cycle, tee, zip_longest
def cyclical_zip(*iterables):
iterables_1, iterables_2 = zip(*map(tee, iterables)) # Allow proper iteration of iterators
for _, x in zip(
zip_longest(*iterables_1), # Limit by the length of the longest iterable
zip(*map(cycle, iterables_2))): # the cycling
yield x
assert list(cyclical_zip([1, 2, 3], 'abcd', 'xy')) == [(1, 'a', 'x'), (2, 'b', 'y'), (3, 'c', 'x'), (1, 'd', 'y')] # An example and test case
解决方案 8:
尝试这样做:
my_list=[ 1, 2, 3, 5, 5, 9]
another_list=['Yes','No']
if type(len(my_list)/2) == float:
ml=int(len(my_list)/2)+1
else:
ml=int(len(my_list)/2)
print([[x,y] for x,y in zip(my_list,another_list*ml)])
原生方式:
尝试计算并四舍五入第一个列表长度的一半,如果它是浮点数,则也加 1
使用
zip()
之前计算出的数字乘以第二个 YesNo 列表进行迭代
解决方案 9:
您可以%
在计数循环中使用模数运算符
my_list=[1, 2, 3, 5, 5, 9]
another_list=['Yes','No']
new_list = []
for cur in range(len(my_list)):
new_list.append([my_list[cur], another_list[cur % 2]])
# [[1, 'Yes'], [2, 'No'], [3, 'Yes'], [5, 'No'], [5, 'Yes'], [9, 'No']]
2
可以替换为len(another_list)
解决方案 10:
对称,无条件一行
[*zip(A*(len(B)//len(A) + 1), B*(len(A)//len(B) + 1))]
严格回答‘如何压缩两个不同大小的列表?’
需要一个补丁来使大小相等的列表具有通用性:
[*(zip(A, B) if len(A) == len(B)
else zip(A*(len(B)//len(A) + 1),
B*(len(A)//len(B) + 1)))]
解决方案 11:
我喜欢Henry Yik 的答案,而且执行速度更快,但这是一个不使用 itertools 的答案。
my_list = [1, 2, 3, 5, 5, 9]
another_list = ['Yes', 'No']
new_list = []
for i in range(len(my_list)):
new_list.append([my_list[i], another_list[i % len(another_list)]])
new_list
[[1, 'Yes'], [2, 'No'], [3, 'Yes'], [5, 'No'], [5, 'Yes'], [9, 'No']]
解决方案 12:
让我们使用np.tile
和zip
:
my_list = [1, 2, 3, 5, 5, 9]
another_list = ['Yes', 'No']
list(zip(my_list,np.tile(another_list, len(my_list)//len(another_list) + 1)) )
输出:
[(1, 'Yes'), (2, 'No'), (3, 'Yes'), (5, 'No'), (5, 'Yes'), (9, 'No')]
解决方案 13:
可能有更好的方法,但您可以创建一个函数,将列表重复到您想要的长度。
def repeatlist(l,i):
'''give a list and a total length'''
while len(l) < i:
l += l
while len(l) > i:
l.pop()
然后做
repeatlist(B,len(A))
zip_list = zip(A,B)
解决方案 14:
如今有了列表推导
[(i, B[i % 3 - 1]) for i in A]
或者如果元素A
不是连续的,并且不用担心列表长度
[(j, B[i % len(B)]) for i, j in enumerate(A)] if len(A) >= len(B) else \n[(A[i % len(A)], j) for i, j in enumerate(B)]
解决方案 15:
d1=['one','two','three']
d2=[1,2,3,4,5]
拉链
zip(d1,d2)
<zip object at 0x05E494B8>
邮编列表
list(zip(d1,d2))
zip 列表字典
{'one': 1, 'two': 2, 'three': 3}
注意:Python 3.7+
相关推荐
热门文章
项目管理软件有哪些?
热门标签
云禅道AD