Подтвердить что ты не робот

Сортировка набора значений

У меня есть такие значения:

set(['0.000000000', '0.009518000', '10.277200999', '0.030810999', '0.018384000', '4.918560000'])
set(['4.918859000', '0.060758000', '4.917336999', '0.003949999', '0.013945000', '10.281522000', '0.025082999'])  

Я хочу сортировать значения в каждом set в порядке возрастания. Я не хочу сортировать между наборами, но значения в каждом наборе.

4b9b3361

Ответ 1

Из комментария:

Я хочу сортировать каждый набор.

Это легко. Для любого набора s (или чего-либо еще итеративного) sorted(s) возвращает список элементов s в отсортированном порядке:

>>> s = set(['0.000000000', '0.009518000', '10.277200999', '0.030810999', '0.018384000', '4.918560000'])
>>> sorted(s)
['0.000000000', '0.009518000', '0.018384000', '0.030810999', '10.277200999', '4.918560000']

Обратите внимание, что sorted предоставляет вам list, а не set. Это потому, что вся точка набора, как в mathematics, так и в почти каждый язык программирования, * заключается в том, что он не упорядочен: наборы {1, 2} и {2, 1} являются одинаковыми.


Вероятно, вы действительно не хотите сортировать эти элементы как строки, а как цифры (так что 4.918560000 поступит раньше 10.277200999, а не после).

Лучшее решение, скорее всего, сохранит числа в виде чисел, а не строк. Но если нет, вам просто нужно использовать функцию key:

>>> sorted(s, key=float)
['0.000000000', '0.009518000', '0.018384000', '0.030810999', '4.918560000', '10.277200999']

Для получения дополнительной информации см. Сортировка HOWTO в официальных документах.


* См. комментарии для исключений.