我想根据列表中的数字与给定数字的接近程度对列表进行排序。举个例子:
target_list = [1,2,8,20]
number = 4那么排序后的列表可能是[2,1,8,20]的,因为:
4-2 = 2
4-1 = 3
|4-8| = 4
|4-20| = 16在发生冲突的情况下,我真的不关心哪个先到,但然后我会尝试根据这个距离度量对列表进行排序。要做到这一点,最好的(和pythonic式的)方法是什么?
发布于 2012-04-24 03:06:38
您可以使用sorted函数的key参数
>>> target_list = [1,2,8,20]
>>> sorted(target_list, key=lambda x: abs(4-x))
[2, 1, 8, 20]或者,如果您想就地对其进行排序,甚至list sort方法也接受key。
>>> target_list.sort(key=lambda x: abs(4-x))
>>> target_list
[2, 1, 8, 20]发布于 2012-04-24 03:07:08
sorted(target_list, key=lambda k: abs(k - 4))或者对列表进行就地排序:
target_list.sort(key=lambda k: abs(k - 4))发布于 2012-04-24 03:09:20
>>> target_list.sort(key=lambda x: abs(number-x))
>>> target_list
[2, 1, 8, 20]https://stackoverflow.com/questions/10286638
复制相似问题