我有这样的价值观:
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'])
Run Code Online (Sandbox Code Playgroud)
我想set
按递增的顺序对每个值进行排序.我不想在集合之间进行排序,而是在每个集合中进行排序.
aba*_*ert 185
来自评论:
我想对每一组进行排序.
这很简单.对于任何集合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']
Run Code Online (Sandbox Code Playgroud)
请注意,这sorted
是给你一个list
,而不是一个set
.这是因为在数学和几乎所有编程语言中,集合的整个点都是它不是有序的:集合{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']
Run Code Online (Sandbox Code Playgroud)
有关更多信息,请参阅官方文档中的排序HOWTO.
*请参阅有关例外的评论.