Python - 如何将嵌套列表拆分为更多列表?

时间:2012-08-26 23:37:08

标签: python list nested-lists

我有一个与此类似的嵌套列表,并按时间升序排序:

[[TIME, 'b', 0],
[TIME, 'b', 1],
[TIME, 'b', 1],
[TIME, 'b', 1],
[TIME, 'b', 10],
[TIME, 'b', 0],
[TIME, 'b', 1],
[TIME, 'b', 1],
[TIME, 'b', 10],
[TIME, 'b', 0],
[TIME, 'b', 1],
[TIME, 'b', 1],
[TIME, 'b', 1],
[TIME, 'b', 1],
[TIME, 'b', 10]]

每个列表中的第三项是0,1或10. 0表示开始,1表示移动,10表示结束。如何将其拆分为另一个嵌套列表,这样我最终会得到一个类似于此的旅程列表:

[[[TIME, 'b', 0],[TIME, 'b', 1],[TIME, 'b', 1],[TIME, 'b', 1],[TIME, 'b', 10]],
[[TIME, 'b', 0],[TIME, 'b', 1],[TIME, 'b', 1],[TIME, 'b', 10]],
[[TIME, 'b', 0],[TIME, 'b', 1],[TIME, 'b', 1],[TIME, 'b', 1],[TIME, 'b', 1],[TIME, 'b', 10]]]

5 个答案:

答案 0 :(得分:4)

可能有更多的pythonic方式来做到这一点,但这是功能性的,直接的,应该很容易遵循。 biglist保存初始数据。

newlist = []
sublist = []
for i in biglist:
    sublist.append(i)
    if i[2] == 10:
        newlist.append(sublist)
        sublist = []

给出:

[[[TIME, 'b', 0],[TIME, 'b', 1],[TIME, 'b', 1],[TIME, 'b', 1],[TIME, 'b', 10]],
[[TIME, 'b', 0],[TIME, 'b', 1],[TIME, 'b', 1],[TIME, 'b', 10]],
[[TIME, 'b', 0],[TIME, 'b', 1],[TIME, 'b', 1],[TIME, 'b', 1],[TIME, 'b', 1],[TIME, 'b', 10]]]

答案 1 :(得分:1)

#x is your initial list
k, new_list = 0, []
for i,j in enumerate(x):
    if j[2] == 10:
        new_list.append(x[k:i+1])
        k = i+1

答案 2 :(得分:1)

与其他解决方案相反,我们在这里测试旅程是否开始(d[2] == 0)而不是结束时:

output = []
for d in data:
    if d[2] == 0:
        # Starting a new journey: we add a new list
        output.append([d])
    else:
        # Continuing a journey: we extend the last list
        output[-1].extend([d])

当然,如果第一次旅程永远不会开始,你就会失败(你会从IndexError声明中得到else)......

答案 3 :(得分:0)

最明显的解决方案,如果我已正确理解问题:

def iter_journeys(lst):
    for e in lst:
        act = e[2]

        if act == 0:
            journey = []

        journey.append(e)

        if act == 10:
            yield journey

答案 4 :(得分:0)

我确信这是一种更有效的方法,但这是一个基本的解决方案:

def create_journeys(paths):
  journeys = [[]]

  for path in paths:
    journeys[-1].append(path)

    if path[-1] == 10:
      journeys.append([])

  return journeys