我有一个列表:
['S1', 'S2', 'S6', 'S1', 'S2', 'S3', 'S4', 'S5', 'S1', 'S2', 'S5', 'S1',
'S2', 'S4', 'S5', 'S1', 'S2', 'S4', 'S5', 'S1', 'S2', 'S3', 'S6']
我想按下一个S1划分:
[['S1', 'S2', 'S6']['S1', 'S2', 'S3', 'S4', 'S5'],['S1', 'S2', 'S4', 'S5]...]
我的代码是:
size = len(steps)
idx_list = [idx + 1 for idx, val in
enumerate(steps) if val == 'S1']
res = [steps[i: j] for i, j in
zip([0] + idx_list, idx_list +
([size] if idx_list[-1] != size else []))]
print("The list after splitting by a value : " + str(res))
它将列表拆分为:
[['S1'], ['S2', 'S6', 'S1'], ['S2', 'S3', 'S4', 'S5', 'S1'],
['S2', 'S5', 'S1'], ['S2', 'S4', 'S5', 'S1'], ['S2', 'S4', 'S5', 'S1']..
请帮忙纠正一下!
答案 0 :(得分:0)
您可以使用itertools.groupby
:
from itertools import groupby
lst = ['S1', 'S2', 'S6', 'S1', 'S2', 'S3', 'S4', 'S5', 'S1', 'S2', 'S5', 'S1', 'S2', 'S4', 'S5', 'S1', 'S2', 'S4', 'S5', 'S1', 'S2', 'S3', 'S6']
splitby = 'S1'
res = [[splitby] + list(g) for k, g in groupby(lst, key=lambda x: x != splitby) if k]
# [['S1', 'S2', 'S6'], ['S1', 'S2', 'S3', 'S4', 'S5'], ['S1', 'S2', 'S5'], ['S1', 'S2', 'S4', 'S5'], ['S1', 'S2', 'S4', 'S5'], ['S1', 'S2', 'S3', 'S6']]
答案 1 :(得分:0)
您有一个off-by-one error。更改以下行:
idx_list = [idx + 1 for idx, val in
enumerate(steps) if val == 'S1']
到
idx_list = [idx for idx, val in
enumerate(steps) if val == 'S1' and idx > 0]
结果应为:
[['S1', 'S2', 'S6'], ['S1', 'S2', 'S3', 'S4', 'S5'],
['S1', 'S2', 'S5'], ['S1', 'S2', 'S4', 'S5'],
['S1', 'S2', 'S4', 'S5'], ['S1', 'S2', 'S3', 'S6']]