Но когда я пытаюсь отсортировать список этих объектов, порядок не соответствует моей логике сравнения.
Вот минимальный воспроизводимый пример:
Код: Выделить всё
class Item:
def __init__(self, value):
self.value = value
def __lt__(self, other):
print("Comparing", self.value, "and", other.value)
return self.value > other.value # reverse sorting
items = [Item(1), Item(3), Item(2)]
sorted_items = sorted(items)
print([i.value for i in sorted_items])
Output:
[1, 2, 3]
Почему Python игнорирует мой собственный метод сравнения и как я могу заставить его уважать его?
Подробнее здесь: https://stackoverflow.com/questions/798 ... -a-list-of
Мобильная версия