我正在尝试从python中的列表中生成一堆对 - 我想出了一种使用for循环的方法:
keys = range(10)
keypairs = list()
for i in range(len(keys)):
for j in range(i+1, len(keys)):
keypairs = keypairs + [(keys[i], keys[j])]
有更多“python风格”的方式吗?我的方法似乎不太优雅......
答案 0 :(得分:2)
你需要两个范围循环,一个从0到n,内部从第一个范围的每个i + 1到n使用列表comp:
n = 10
pairs = [(i, j) for i in range(n) for j in range(i+1, n)]
from pprint import pprint as pp
pp(pairs,compact=True)
[(0, 1), (0, 2), (0, 3), (0, 4), (0, 5), (0, 6), (0, 7), (0, 8), (0, 9), (1, 2),
(1, 3), (1, 4), (1, 5), (1, 6), (1, 7), (1, 8), (1, 9), (2, 3), (2, 4), (2, 5),
(2, 6), (2, 7), (2, 8), (2, 9), (3, 4), (3, 5), (3, 6), (3, 7), (3, 8), (3, 9),
(4, 5), (4, 6), (4, 7), (4, 8), (4, 9), (5, 6), (5, 7), (5, 8), (5, 9), (6, 7),
(6, 8), (6, 9), (7, 8), (7, 9), (8, 9)]
与您的输出完全匹配。
答案 1 :(得分:1)
您想检查列表理解:
sorted([(i, j) for j in range(10) for i in range(10) if j > i])
答案 2 :(得分:1)
我会使用itertools。检查combinations_with_replacement和combinations方法。
以下是代码示例:
import itertools
list(itertools.combinations(keys, 2))
编辑:是的,我注意到它应该是combinations
,而不是combinations_with_replacements
。