1

我有一个清单:

lists = (['1','2','3','S','3','4','S','4','6','7'])

而且我想在每次出现“S”时将列表拆分为更小的列表,并将“S”消除为:

([['1','2','3'],['3','4],['4','6','7']])

我的代码:

def x (lists):
    empty = ''
    list = []

    for x in lists:
        if x == empty:
            list[-1:].append(x)
        else:
            list.append([x])

    return (list)

我尝试过这样的事情,但我对 python 很陌生,而且我无处可去。没什么特别的,我将如何解决我所拥有的?

4

3 回答 3

5

尝试itertools.groupby()

>>> from itertools import groupby
>>> lists = ['1','2','3','S','3','4','S','4','6','7']
>>> [list(g[1]) for g in groupby(lists, lambda i:i!='S') if g[0]]
[['1', '2', '3'], ['3', '4'], ['4', '6', '7']]
于 2012-11-16T05:43:52.727 回答
1

好吧,可能很有趣,但这应该有效:

[s.split('#') for s in '#'.join(lists).split('#S#')]

如果它不太'#'可能出现在lists.

于 2012-11-16T05:50:22.413 回答
1

也许像map(list,''.join(lists).split('S'))

交替,[list(s) for s in ''.join(lists).split('S'))

于 2012-11-16T05:41:14.173 回答