嘿,我在试着生成一个列表的子列表。例如,我有一个这样的列表:
l = [1,2,3,4,5,6,7,8,9,10,11,12]
我想把它们分割成长度为4的子列表。但是,第一个元素与前一个列表中的最后一个元素相同,就像我说的那样,它的长度必须是4。
l1 = [1,2,3,4]
l2 = [4,5,6,7]
l3 = [7,8,9,10]
l4 = [10, 11, 12] <-- should be ignored有人有主意吗?!我在想一台发电机但我不太确定。
发布于 2014-06-20 13:14:08
一个简单但灵活的生成器实现:
def overlapping_sublists(l, n, overlap=1, start=0):
while start <= len(l) - n:
yield l[start:start+n]
start += n - overlap示例用法:
>>> l = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12]
>>> list(overlapping_sublists(l, 4))
[[1, 2, 3, 4], [4, 5, 6, 7], [7, 8, 9, 10]]
>>> list(overlapping_sublists(l, 4, 2, 3))
[[4, 5, 6, 7], [6, 7, 8, 9], [8, 9, 10, 11]]发布于 2014-06-20 13:09:21
a = []
l = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12]
for i in range(0, len(l)-3, 3):
a.append(l[i:i+4])会给a = [[1, 2, 3, 4], [4, 5, 6, 7], [7, 8, 9, 10]]
或者你可以用它来理解列表:
[l[i:i+4] for i in range(0, len(l)-3, 3)]发布于 2014-06-20 13:09:11
print([l[i:i+4] for i in range(0, len(l), 3)])输出:
[[1, 2, 3, 4], [4, 5, 6, 7], [7, 8, 9, 10], [10, 11, 12]]只有长度4的子列表:
print([m for m in [l[i:i+4] for i in range(0, len(l), 3)] if len(m) == 4])输出:
[[1, 2, 3, 4], [4, 5, 6, 7], [7, 8, 9, 10]]使用发电机:
for n in (m for m in (l[i:i+4] for i in range(0, len(l), 3)) if len(m) == 4):
print(n)输出:
[1, 2, 3, 4]
[4, 5, 6, 7]
[7, 8, 9, 10]https://stackoverflow.com/questions/24327964
复制相似问题