python順序を保持したまま配列の要素をユニーク(一意)にする


配列要素をユニークにしたい

普通はこうするのだが、元データの順序性が崩れてしまう。
setの性質上仕方ない。

>>> dat = [3,2,1,5,1,2]
>>> list(set(dat))
[1, 2, 3, 5]

元の順序は維持した状態でユニークにする

>>> from more_itertools import unique_everseen
>>> list(unique_everseen(dat))

[3, 2, 1, 5]
# 元の順序が維持されかつユニークになった

一意判定条件がもうちょっと複雑なケース

dat2 = [(3, "b"), (2, "a"), (1, "a"), (2, "b")]
# -> 例として2次元配列があり、"a","b","c"の値をキーとしたuniqなデータを取り出したいとする

>>> list(unique_everseen(dat2, key=lambda x: x[1]))
[(3, 'b'), (2, 'a')]
# みたいな感じ