繁体   English   中英

需要按嵌套值列表的平均值对字典进行排序

[英]Need to sort a dictionary by average of nested list of values

dict = {a:[2,4,5],b:[4,6,7],c:[3,1,1]}

上面是我有字典的一个例子。 嵌套列表的长度将始终为3(由于其他代码块)。 我已经弄清楚了如何按字母顺序和字典中列表的最高值排序。 我正在努力寻找一种方法来计算最高的平均得分。 以下是所需的输出:

>>> get_average(dict)
>>> b : 5.66
>>> a : 3.66
>>> c : 1.66

有任何提示或解决方案吗? 我敢肯定,最有效的方法是使用lambda。 我可以修改此代码以获取平均值:

sorted(dict.items(), key=operator.itemgetter(1))

首先,使用dict理解构建平均值图:

>>> d = {'a':[2,4,5], 'b':[4,6,7], 'c':[3,1,1]}
>>> def mean(L):
        return float(sum(L))/len(L)
... 
>>> d_avg = {k: mean(v) for k, v in d.items()}
>>> d_avg
{'a': 3.6666666666666665, 'b': 5.666666666666667, 'c': 1.6666666666666667}

然后,您可以按值对它进行排序:

>>> sorted(d_avg, key=d_avg.get, reverse=True)
['b', 'a', 'c']

尝试这个:

 d = {'a':[2,4,5], 'b':[4,6,7], 'c':[3,1,1]}
 sort = sorted(d, key=lambda k: sum(d[k]) / 3, reverse=True)
 for i in sort:
     print(i, ":", sum(d[i]) / 3)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM