[英]How to have primary and secondary sorting stipulations for a list of lists in Python
我有这个列表列表:
myList = [[1, 200], [3, 200], [4, 300], [2, 200], [1, 300]]
并且想知道我如何主要按每个嵌套列表中的第二项对其进行排序,然后再按第一项进行排序。
我希望列表按以下顺序结束:
[[1, 200], [2, 200], [3, 200], [1, 300], [4, 300]]
我已经完成了myList.sort(key = lambda x: x[1])
但这仅按第二项排序。 我不确定如何有初级和次级排序规定。
谢谢!
import operator
myList = [[1, 200], [3, 200], [4, 300], [2, 200], [1, 300]]
new = sorted(myList, key=operator.itemgetter(1, 0))
print (new)
您只需要在 itemgetter() 中提及优先级。 1 第一个代表第二个 position,然后 0 代表第一个。
Output:
[[1, 200], [2, 200], [3, 200], [1, 300], [4, 300]]
您可以尝试使用两者进行排序:
>>> myList = [[1, 200], [3, 200], [4, 300], [2, 200], [1, 300]]
>>> sorted(myList, key=lambda x: x[::-1])
[[1, 200], [2, 200], [3, 200], [1, 300], [4, 300]]
>>>
上面的代码按两个值排序,但它首先按第二个值排序,然后如果第二个值与其他值相同,则按第一个值排序。
sort
方法的key
参数也可以是一个元组,而不是每个 object 的属性或元素,通常是这样。 这里的项目按它们的第二个元素排序,然后按它们的第一个元素。
# Initial list
myList = [[1, 200], [3, 200], [4, 300], [2, 200], [1, 300]]
# Sort list in-place
myList.sort(key=lambda x: (x[1], x[0]))
# Print myList
print(myList)
退货
[[1, 200], [2, 200], [3, 200], [1, 300], [4, 300]]
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.