sorting一组值
我有这样的价值观:
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
中的值进行sorting。 我不想在集合之间进行sorting,而是在每个集合中进行sorting。
从评论:
我想对每一组进行sorting。
这很容易。 对于任何集合s
(或其他可迭代), sorted(s)
以sorting顺序返回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
。 这是因为在math和几乎所有的编程语言中 ,一个集合的全部要点是它不是有序的:集合{1, 2}
和{2, 1}
是同一集合。
你可能真的不想把这些元素sorting为string,而是作为数字(所以4.918560000会在10.277200999之前,而不是之后)。
最好的解决scheme是最有可能将数字存储为数字而不是string。 但是,如果没有,你只需要使用一个key
function:
>>> sorted(s, key=float) ['0.000000000', '0.009518000', '0.018384000', '0.030810999', '4.918560000', '10.277200999']
有关更多信息,请参阅官方文档中的Sorting HOWTO 。
*查看exception的评论。