2016-11-24 124 views
3

我不知道它是否可行。我试图找到下列条件排序嵌套列表的方式嵌套列表和python排序

  1. 我要排序表格1点到另一个(不是整个名单只是其中的一部分)
  2. 排序应该上完成子列表

的我想要什么的观念的第三个要素的基础上:

PAE=[['a',0,8], 
     ['b',2,1], 
     ['c',4,3], 
     ['d',7,2], 
     ['e',8,4]] 

    #PAE[1:4].sort(key=itemgetter(2)) (something like this)  
    or  
    #sorted(PAE[1:4],key=itemgetter(2)) (something like this) 
` #^i know both are wrong but just for an idea 
` 
    #output should be like this 
    ['a', 0, 8] 
    ['b', 2, 1] 
    ['d', 7, 2] 
    ['c', 4, 3] 
    ['e', 8, 4] 

我是新来的蟒蛇,但我想我的水平最好找到一个解决方案,但失败了。

回答

3

排序切片和写回

>>> PAE[1:4] = sorted(PAE[1:4], key=itemgetter(2)) 
>>> PAE 
[['a', 0, 8], ['b', 2, 1], ['d', 7, 2], ['c', 4, 3], ['e', 8, 4]] 
+0

谢谢。简短而正确的答案。 – Syed

3

这应该这样做:

from operator import itemgetter 
PAE=[['a',0,8], 
    ['b',2,1], 
    ['c',4,3], 
    ['d',7,2], 
    ['e',8,4]] 

split_index = 1 

print PAE[:split_index]+sorted(PAE[split_index:],key=itemgetter(2)) 
#=> [['a', 0, 8], ['b', 2, 1], ['d', 7, 2], ['c', 4, 3], ['e', 8, 4]] 
+0

谢谢你的解决方案。 – Syed

0

这里不裂倾向,问题是,什么是最好的可读性

PAE=[['a',0,8], 
    ['b',2,1], 
    ['c',4,3], 
    ['d',7,2], 
    ['e',8,4]] 

print (sorted(PAE, key=lambda PAE: PAE[1] if not PAE[1] else PAE[2])) 
>>> [['a', 0, 8], ['b', 2, 1], ['d', 7, 2], ['c', 4, 3], ['e', 8, 4]] 
+1

我不认为它回答了这个问题。你的排序取决于每个列表的第二个元素,对吧? –

+1

没有埃里克,在这种情况下,排序键是相对的 –

+1

是的,但问题没有提到它。 –