2016-01-16 1 views
13

Я пытаюсь получить список трехэлементных кортежей из списка [-4, -2, 1, 2, 5, 0] с использованием понятий и проверки того, выполняют ли они условие sum([] == 0). Следующий код работает. Тем не менее, нет никаких сомнений в том, что должно быть проще, гораздо более изящный способ выражения этих постижений:Понимания в Python для выборки кортежей из списка

[ 
    (i, j, k) for i in [-4, -2, 1, 2, 5, 0] 
       for j in [-4, -2, 1, 2, 5, 0] 
       for k in [-4, -2, 1, 2, 5, 0] if sum([i, j, k]) == 0 
] 

Выход:

[(-4, 2, 2), (-2, 1, 1), (-2, 2, 0), (-2, 0, 2), (1, -2, 1), 
(1, 1, -2), (2, -4, 2), (2, -2, 0), (2, 2, -4), (2, 0, -2), 
(0, -2, 2), (0, 2, -2), (0, 0, 0)] 

Вопрос ищет выражения, как (i, j, k) for i, j, k in [-4, -2, 1, 2, 5, 0].

+0

ли повторенное значение разрешено? – Arman

ответ

19

Вы можете использовать itertools.product, чтобы скрыть вложенные циклы в вашем понимании списка. Используйте параметр repeat, чтобы установить количество петель по списку (то есть количество элементов в наборе):

>>> import itertools 
>>> lst = [-4, -2, 1, 2, 5, 0] 
>>> [x for x in itertools.product(lst, repeat=3) if sum(x) == 0] 
[(-4, 2, 2), 
(-2, 1, 1), 
(-2, 2, 0), 
(-2, 0, 2), 
(1, -2, 1), 
(1, 1, -2), 
(2, -4, 2), 
(2, -2, 0), 
(2, 2, -4), 
(2, 0, -2), 
(0, -2, 2), 
(0, 2, -2), 
(0, 0, 0)]