У меня была похожая проблема, и я нашел решение здесь . Работает без импорта какого-либо модуля.
Предположим, что список выглядит так:
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')
Редактировать: После переделки, чтобы упростить это решение, я понял, что это тот же подход, что и Адам Розенфилд. Я надеюсь, что более широкое объяснение поможет некоторым лучше понять его.