Python根据标准框中的第一个元素分为标准列表



我想拆分一个看起来像这样的列表:

list = [5, a, b, c, d, e, 2, a, b, 4, a ,b ,c ,d , ...]

进入这个:

list  = [ [5, a, b, c, d, e], [2, a, b] , [4, a ,b ,c ,d] ...]

第一个元素/数字是可变的,因此甚至没有模式将其分成块。块的大小或长度应基于块的第一个元素。同样,字母字母只是占位符,可以使示例更可读,实际上,字母字母是浮标和数字。

所以大列表确实看起来像这样:

list = [5, 7, 3.2, 3.1, 4.6, 3, 2, 5.1, 7.1, 4, 5.12 ,3.4 ,4.8 ,12.1 , ...]

简单的方式,读取每个块长度n并包括下一个n值:

it = iter(l)
[[n, *islice(it, n)] for n in it]

Python 2版本:

it = iter(l)
[[n] + list(islice(it, n)) for n in it]

或没有islice

it = iter(l)
[[n] + [next(it) for _ in range(n)] for n in it]

演示:

>>> from itertools import islice
>>> l = [5, 'a', 'b', 'c', 'd', 'e', 2, 'f', 'g', 4, 'h' ,'i' ,'j' ,'k']
>>> it = iter(l)
>>> [[n, *islice(it, n)] for n in it]
[[5, 'a', 'b', 'c', 'd', 'e'], [2, 'f', 'g'], [4, 'h', 'i', 'j', 'k']]

您可以尝试一下:

l = [5, 'a', 'b', 'c', 'd', 'e', 2, 'a', 'b', 4, 'a' ,'b' ,'c' ,'d']
pos = [(index, i) for index, i in enumerate(l) if type(i)==int]
l = [l[p[0]:p[0]+p[1]+1] for p in pos]
print(l)

输出:

[[5, 'a', 'b', 'c', 'd', 'e'], [2, 'a', 'b'], [4, 'a', 'b', 'c', 'd']]

也可以尝试简单的东西:

l = [5, 'a', 'b', 'c', 'd', 'e', 2, 'f', 'g', 4, 'h' ,'i' ,'j' ,'k']
numbers = [i for i, e in enumerate(l) if isinstance(e, int)]
result = [l[s:e] for s, e in zip(numbers[:-1], numbers[1:])] + [l[numbers[-1]:]]
print(result)
# [[5, 'a', 'b', 'c', 'd', 'e'], [2, 'f', 'g'], [4, 'h', 'i', 'j', 'k']]

相关内容

  • 没有找到相关文章

最新更新