%20%D0%BC%D0%BD%D0%BE%D0%B6%D0%B5%D1%81%D1%82%D0%B2%D0%B0%20%D0%B2%20%D0%BF%D0%BE%D0%BD%D0%B8%D0%BC%D0%B0%D0%BD%D0%B8%D0%B8%20%D1%81%D0%BF%D0%B8%D1%81%D0%BA%D0%B0.png)
Я наткнулся на следующий код для удаления дубликатов из списка:
seen = set(); print [i for i in list if i not in seen and not seen.add(i)]
Я не мог понять, что именно.и не видел.add(i)"эта часть кода работает какпомощь(установить.добавить)дает ниже объяснение:
add(...)
Add an element to a set.
This has no effect if the element is already present.
С нетерпением жду вашей помощи в понимании этого.
решение1
Списочное включение перебирает значения исходного/входного списка. Мы хотим, чтобы значение было добавлено в новый/выходной список, если и только если оно еще не было просмотрено, отсюда и условное выражение if i not in seen
. Когда новое значение добавляется в новый/выходной список, seen
набор должен быть обновлен, отсюда и seen.add(i)
вызов функции. Однако set.add()
метод возвращает None
, что вычисляется как False
. Поэтому not
оператор добавляется, так что not seen.add(i)
всегда возвращает True
.