Python - отсортируйте список вложенных списков

Вы не согласны, считывая пиксели из изображения, преобразованного RGBA, но устанавливая пиксели в исходном изображении, возможно, не в RGBA. Исправление, которое заставляет ваш код работать с образцом изображения.

pix = rgb_im.load()
13
задан Claudiu 11 November 2008 в 07:15
поделиться

3 ответа

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

>>> 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]]
16
ответ дан 1 December 2019 в 19:51
поделиться

Немного рекурсивной функции сделало бы это:

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
12
ответ дан 1 December 2019 в 19:51
поделиться
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
5
ответ дан 1 December 2019 в 19:51
поделиться
Другие вопросы по тегам:

Похожие вопросы: