我有一个与此类似的嵌套列表,并按时间升序排序:
[[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]]]
答案 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