对一组数值进行排序

185
我有这样的数值:
x = set(['0.000000000', '0.009518000', '10.277200999', '0.030810999', '0.018384000', '4.918560000'])
y = set(['4.918859000', '0.060758000', '4.917336999', '0.003949999', '0.013945000', '10.281522000', '0.025082999'])  

我想按照递增顺序对每个“set”中的值进行排序。我不想在集合之间进行排序,而是对每个集合中的值进行排序。
2个回答

336

来自评论:

我想对每个集合进行排序。

那很简单。对于任何集合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 给你的是一个列表,而不是一个集合。这是因为在数学几乎所有编程语言中,集合的整个意义在于它是无序的:集合 {1, 2}{2, 1} 是相同的集合。

您可能不想将这些元素按字符串排序,而是按数字排序(因此4.918560000将在10.277200999之前而不是之后)。

最好的解决方案很可能是在第一次存储数字时将其存储为数字而不是字符串。但如果不是这样,您只需要使用一个键函数:

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

更多信息请参见官方文档中的排序指南


* 请查看注释以获取异常信息。


是的!终于我学会了如何将集合转换为列表! - dsgdfg

2

自 Python 3.7 开始,字典保持插入顺序。因此,如果您想对集合进行排序,但仍希望能够在常数时间内执行成员资格检查,则可以使用 dict.fromkeys() 从已排序的列表创建字典(默认情况下值为 None)。

s = {10, 39, 3}

s_sorted = dict.fromkeys(sorted(s))               # ascending order
# {3: None, 10: None, 39: None}

s_sorted = dict.fromkeys(sorted(s, reverse=True)) # descending order
# {39: None, 10: None, 3: None}

1
有一个字典,其所有值都是None,这有点奇怪,但这正是我正在寻找的。谢谢。 - rhedak

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接