Проверить product()
в itertools
модуле. Это именно то, что вы описываете.
import itertools
my_list = [1,2,3,4]
for pair in itertools.product(my_list, repeat=2):
foo(*pair)
Это эквивалентно:
my_list = [1,2,3,4]
for x in my_list:
for y in my_list:
foo(x, y)
Изменить: есть две очень похожие функции permutations()
и combinations()
. Чтобы проиллюстрировать, чем они отличаются:
product()
генерирует все возможные пары элементов, включая все дубликаты:
1,1 1,2 1,3 1,4
2,1 2,2 2,3 2,4
3,1 3,2 3,3 3,4
4,1 4,2 4,3 4,4
permutations()
генерирует все уникальные порядки каждой уникальной пары элементов, удаляя x,x
дубликаты:
. 1,2 1,3 1,4
2,1 . 2,3 2,4
3,1 3,2 . 3,4
4,1 4,2 4,3 .
Наконец, combinations()
генерирует только каждую уникальную пару элементов в лексикографическом порядке:
. 1,2 1,3 1,4
. . 2,3 2,4
. . . 3,4
. . . .
Все три функции были введены в Python 2.6.
permutations()
иcombinations()
использоватьr=2
вместоrepeat=2
использованного в примере дляproduct()
У меня была аналогичная проблема, и я нашел решение здесь . Он работает без необходимости импорта какого-либо модуля.
Допустим, список вроде:
people = ["Lisa","Pam","Phil","John"]
Упрощенное однострочное решение могло бы выглядеть так.
Все возможные пары , включая дубликаты:
result = [foo(p1, p2) for p1 in people for p2 in people]
Все возможные пары, исключая дубликаты :
result = [foo(p1, p2) for p1 in people for p2 in people if p1 != p2]
Уникальные пары , порядок которых не имеет значения:
result = [foo(people[p1], people[p2]) for p1 in range(len(people)) for p2 in range(p1+1,len(people))]
Если вы не хотите работать, а просто хотите получить пары, достаточно будет удалить функцию
foo
и использовать только кортеж.Все возможные пары , включая дубликаты:
list_of_pairs = [(p1, p2) for p1 in people for p2 in people]
Результат:
('Lisa', 'Lisa') ('Lisa', 'Pam') ('Lisa', 'Phil') ('Lisa', 'John') ('Pam', 'Lisa') ('Pam', 'Pam') ('Pam', 'Phil') ('Pam', 'John') ('Phil', 'Lisa') ('Phil', 'Pam') ('Phil', 'Phil') ('Phil', 'John') ('John', 'Lisa') ('John', 'Pam') ('John', 'Phil') ('John', 'John')
Все возможные пары, исключая дубликаты :
list_of_pairs = [(p1, p2) for p1 in people for p2 in people if p1 != p2]
Результат:
('Lisa', 'Pam') ('Lisa', 'Phil') ('Lisa', 'John') ('Pam', 'Lisa') ('Pam', 'Phil') ('Pam', 'John') ('Phil', 'Lisa') ('Phil', 'Pam') ('Phil', 'John') ('John', 'Lisa') ('John', 'Pam') ('John', 'Phil')
Уникальные пары , порядок которых не имеет значения:
list_of_pairs = [(people[p1], people[p2]) for p1 in range(len(people)) for p2 in range(p1+1,len(people))]
Результат:
('Lisa', 'Pam') ('Lisa', 'Phil') ('Lisa', 'John') ('Pam', 'Phil') ('Pam', 'John') ('Phil', 'John')
Изменить: после переделки, чтобы упростить это решение, я понял, что это тот же подход, что и у Адама Розенфилда. Я надеюсь, что более подробное объяснение поможет некоторым лучше понять это.
источник
Если вы просто вызываете функцию, вы не сможете добиться большего, чем:
for i in my_list: for j in my_list: foo(i, j)
Если вы хотите собрать список результатов вызова функции, вы можете:
[foo(i, j) for i in my_list for j in my_list]
который вернет вам список результатов применения
foo(i, j)
к каждой возможной паре(i, j)
.источник
my_list = [1,2,3,4] pairs=[[x,y] for x in my_list for y in my_list] print (pairs)
источник