У меня есть список Python, где элементы могут повторяться.
>>> a = [1,2,2,3,3,4,5,6]
Я хочу получить первые n
уникальные элементы из списка.Итак, в этом случае, если мне нужны первые 5 уникальных элементов, они будут:
[1,2,3,4,5]
Я пришел к решению с использованием генераторов:
def iterate(itr, upper=5):
count = 0
for index, element in enumerate(itr):
if index==0:
count += 1
yield element
elif element not in itr[:index] and count<upper:
count += 1
yield element
Используется:
>>> i = iterate(a, 5)
>>> [e for e in i]
[1,2,3,4,5]
Я сомневаюсь, что это самое оптимальное решение.Есть ли альтернативная стратегия, которую я могу реализовать, чтобы написать ее более питонно и эффективно?