Python - сортировка списка вложенных списков - PullRequest
13 голосов
/ 11 ноября 2008

У меня есть вход, состоящий из списка вложенных списков, таких как:

l = [[[[[39]]]], [1, 2, 3], [4, [5, 3], 1], [[[[8, 9], 10], 11], 12]]

Я хочу отсортировать этот список на основе суммы всех чисел во вложенных списках ... поэтому значения, которые я хочу отсортировать по l, будут выглядеть так:

[39, 6, 13, 50]

Тогда я хочу отсортировать на основе этого. Таким образом, вывод должен быть:

[[1, 2, 3], [4, [5, 3], 1], [[[[39]]]], [[[[8, 9], 10], 11], 12]]

Какой хороший питонный способ сделать это?

Ответы [ 3 ]

16 голосов
/ 11 ноября 2008

Небольшое упрощение и обобщение ответов, представленных до сих пор, используя недавнее дополнение к синтаксису питона:

>>> l = [[[[[39]]]], [1, 2, 3], [4, [5, 3], 1], [[[[8, 9], 10], 11], 12]]
>>> def asum(t): return sum(map(asum, t)) if hasattr(t, '__iter__') else t
...
>>> sorted(l, key=asum)
[[1, 2, 3], [4, [5, 3], 1], [[[[39]]]], [[[[8, 9], 10], 11], 12]]
12 голосов
/ 11 ноября 2008

Маленькая рекурсивная функция сделает это:

def asum(a):
    if isinstance(a, list):
        return sum(asum(x) for x in a)
    else:
        return a

l = [[[[[39]]]], [1, 2, 3], [4, [5, 3], 1], [[[[8, 9], 10], 11], 12]]
l.sort(key=asum)
print l
5 голосов
/ 11 ноября 2008
l.sort(key=sum_nested)

Где sum_nested():

def sum_nested(astruct):
    try: return sum(map(sum_nested, astruct))
    except TypeError:
        return astruct


assert sum_nested([[([8, 9], 10), 11], 12]) == 50
...