Ответ 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 в официальных документах.
* См. комментарии для исключений.