Allen Allen - 1 year ago 83
Python Question

Get unique combinations of elements from a python list

This is not a exact duplicate of Python code to pick out all possible combinations from a list?

This topic is about finding unique combinations while the other topic is about finding ALL combinations.

If I have a python list:

L = [1,2,3,4]

what's the best way to get all the possible unique combinations of 3 elements from the list like below:

["1,2,3", "1,2,4", "2,3,4", "3,4,1"]

The order of the elements in the combinations doesn't matter. For example,
will be considered the same combination.

I can probably write a few loops to do this but I think there might be a one-liner which can do the same.

Answer Source

You need itertools.combinations:

>>> from itertools import combinations
>>> L = [1, 2, 3, 4]
>>> [",".join(map(str, comb)) for comb in combinations(L, 3)]
['1,2,3', '1,2,4', '1,3,4', '2,3,4']
Recommended from our users: Dynamic Network Monitoring from WhatsUp Gold from IPSwitch. Free Download