Python 如何根据字典列表中的列表总和对字典列表进行排序?
我有一份字典清单如下:Python 如何根据字典列表中的列表总和对字典列表进行排序?,python,list,dictionary,Python,List,Dictionary,我有一份字典清单如下: list=[{"name":"D","marks":[8,9,7]},{"name":"A","marks":[5,8,9]},{"name":"B","marks":[5,8,2]}] 我想按标记的总和对字典进行排序。您可以使用排序的函数和一个键函数,返回d['marks']的总和(我将其更
list=[{"name":"D","marks":[8,9,7]},{"name":"A","marks":[5,8,9]},{"name":"B","marks":[5,8,2]}]
我想按标记的总和对字典进行排序。您可以使用
排序的函数和一个键函数,返回d['marks']
的总和(我将其更改为l
,因为列表是一个关键字)
list=[{"name":"D","marks":[8,9,7]},{"name":"A","marks":[5,8,9]},{"name":"B","marks":[5,8,2]}]
sorted_list = sorted(list, key=lambda x: sum(x["marks"]))
sorted\u l=sorted(l,key=lambda d:sum(d['marks']))
你到底实现了什么?这个问题被问了很多。当您试图使用带有自定义键的sorted
函数时出现了什么问题?为什么要使用numpy
?来吧,为什么要跳到numpy求和?它内置在标准图书馆里你刚刚复制了我的solution@FlavioMoraes两个人可以独立地提出相同的显而易见的解决方案。在弗拉维奥·莫雷斯的答案发表之前,我就开始研究这个问题。有没有一种方法可以按降序排序,而不用使用reverse=True?-sum(d['marks')
而不是总和(d['marks'])