2014-11-04 69 views
1

我有一個列表,它看起來像這樣: 每個元組都有一個名字,啓動,停止和方向:拆分基於元組的值元組的列表

major_list = [('a',20,30,-1),('b',31,40,-1),('c',41,50,-1),('d',51,60,+1),('z',90,100,-1),('e',61,70,+1),('f',71,80,+1)] 

這就需要分割像此:

[[('a',20,30,-1),('b',31,40,-1),('c',41,50,-1)],[('d',51,60,+1)],[('z',90,100,-1)],[('e',61,70,+1),('f',71,80,+1)]] 

有兩個規則分裂列表: 1)如果ABS(開始 - 停止)相鄰的元組之間的> 20,使一個新的列表[OR] 2)如果相鄰元組具有相反的方向說('c',41,50,-1),('d',51,60,+ 1),做一個新的「C」

這裏後列表是我到目前爲止有:

SplitList = [] 
    for i,tup in enumerate(major_List): 
     if i != len(major_List)-1: 
      if i == 0: 
       tmp_list = [] 
      next_tup = major_List[i+1] 
      if (abs(int(next_tup[1]) - int(tup[2])) > 20) or (next_tup[3] != tup[3]): 
       tmp_list.append(tup) 
       if tmp_list:     
       SplitList.append(tmp_list) 
       tmp_list = [] 
     else: 
      tmp_list.append(tup) 

出於某種原因SplitList在末端插入一個空的列表,我想不出什麼我做錯了。是否有更多pythonic方法來做同樣的事情?

+0

讓我看看我正確地理解了這個問題:你需要一個帶有兩個列表的列表:第一個列表的方向爲-1,第二個列表的方向爲+1的對象? – 2014-11-04 21:51:03

+0

否根據規則(其中2個)原始列表將被拆分成子列表;因此結果列表將是各種列表的列表 – user2998764 2014-11-04 21:56:26

回答

2

如果是在列表中的第一個元素,該元素添加到final列表裏面,然後只檢查所需的子元素中final列表針對當前的最後一個元素:

major_list = [('a',20,30,-1),('b',31,40,-1),('c',41,50,-1),('d',51,60,+1),('z',90,100,-1),('e',61,70,+1),('f',71,80,+1)] 

final = [] 

for ele in major_list: 
    if not final: 
     final.append([ele]) # final is empty so add the first element in a list 
    # check the last item of the last sublist added to final and compare to our current element 
    elif abs(final[-1][-1][1] - ele[2]) > 20 or final[-1][-1][3] != ele[3]: 
    # if it does not meet the requirement, add it to final in a new list 
     final.append([ele]) 
    else: 
     # else add it to the last sublist 
     final[-1].append(ele) 
print(final) 

[[('a', 20, 30, -1), ('b', 31, 40, -1), ('c', 41, 50, -1)], [('d', 51, 60, 1)], [('z', 90, 100, -1)], [('e', 61, 70, 1), ('f', 71, 80, 1)]]