我有这样的价值观:
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。我不想在集合之间进行排序,而是在每个集合中进行排序。
set
来自评论:
我想对每个集合进行排序。
这很容易。对于任何集合s(或其他任何可迭代的对象),以排序顺序sorted(s)返回的元素列表s:
s
sorted(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。这是因为在数学和几乎每种编程语言中,集合的全部要点*都是无序的:集合{1, 2}和{2, 1}是同一集合。
sorted
list
{1, 2}
{2, 1}
您可能真的不想将这些元素排序为字符串,而是将其排序为数字(因此,4.918560000将在10.277200999之前而不是之后)。
最好的解决方案是最有可能首先将数字存储为数字而不是字符串。但是,如果没有,您只需要使用一个key函数:
key
>>> sorted(s, key=float) ['0.000000000', '0.009518000', '0.018384000', '0.030810999', '4.918560000', '10.277200999']
有关更多信息,请参见官方文档中的Sorting HOWTO。
*请参阅注释以了解例外情况。