python - 如何使用Python dict获得类(class)前10名的学生

标签 python dictionary

我有一本包含学生姓名和分数的字典

dict1 = {'name1': 34, 'name2':45, 'name3': 98, 'name4':34, 'name5': 66}

我想从上面的字典中获取前 10 个学生的名字以及他们的分数。

结果:

name3 98
name5 66
name2 45
name1 34
name4 34

对于相同值的多个键,键必须按字母顺序排列(例如:对于相同的值 34,name1 和 name4 按字母顺序排列)

如何完成?

最佳答案

使用heapq.nlargest() :

from heapq import nlargest
from operator import itemgetter

for name, score in nlargest(10, dictionary.iteritems(), key=itemgetter(1)):
    print name, score

演示:

>>> for name, score in nlargest(10, dictionary.iteritems(), key=itemgetter(1)):
...     print name, score
... 
name3 98
name5 66
name2 45
name4 34
name1 34

请注意,因为您的示例字典小于您想要的顶级 n,您也可以使用 sorted():

for name, score in sorted(dictionary.iteritems(), key=itemgetter(1), reverse=True):
    print name, score

但对于n小于len(dictionary)的任何top nheapq是更好的选择.

或者,使用 collections.Counter() 对象,它有一个 .most_common() 方法,可以为您提供准确的信息;计数器中得分最高的 n 元素:

>>> scores = Counter(dictionary)
>>> scores
Counter({'name3': 98, 'name5': 66, 'name2': 45, 'name4': 34, 'name1': 34})
>>> scores.most_common(3)
[('name3', 98), ('name5', 66), ('name2', 45)]

关于python - 如何使用Python dict获得类(class)前10名的学生,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16571420/

相关文章:

python - 运行 python 脚本时出现问题(pypdf/hex 错误)

python - 使用 python 获取 s3 存储桶时出现问题

bash - unix map 功能

python - 在 pandas 上追加后仅保留重复的索引

python - Scipy odeint 以负时间值求值

Python:如何覆盖子类中实例属性的类型提示?

c - 需要帮助打印链接列表的内容

Python:从字典中删除大量键的最快策略

Java 将 Map 传递给可变参数对

javascript - 字典仅包含单个元素