字典重排和排序

时间:2017-06-26 03:24:43

标签: python sorting dictionary

需要计算不同值的数量出现在dict ng set defaults.styleExt scss 中,并且根据值反向输出的出现次数。

books

输出如下:

books = {
    123457889: 'A',
    252435234: 'A',
    434234341: 'B',
    534524365: 'C',
    354546589: 'D',
    146546547: 'D',
    353464543: 'F',
    586746547: 'E',
    511546547: 'F',
    546546647: 'F',
    541146127: 'F',
    246546127: 'A',
    434545127: 'B',
    533346127: 'E',
    544446127: 'F',
    546446127: 'G',
    155654627: 'G',
    546567627: 'G',
    145452437: 'H',
}

我试过了:

'F': 5,
'A': 3,
'G': 3,
'B': 2,
'D': 2,
'E': 2,
'C': 1,
'H': 1

但dict无法排序。

1 个答案:

答案 0 :(得分:5)

您的代码运行正常。使用集合模块中的Counter可以更轻松地完成此操作。只需将books.values()传递给Counter

from collections import Counter
counts = Counter(books.values())
print(counts)

输出:

Counter({'F': 5, 'A': 3, 'G': 3, 'E': 2, 'D': 2, 'B': 2, 'H': 1, 'C': 1})

要按值的顺序提供您期望的输出布局,可以使用most_common方法执行简单迭代并打印每一行:

for char, value in counts.most_common():
    print("'{}': {}".format(char, value))

输出:

'F': 5
'G': 3
'A': 3
'E': 2
'D': 2
'B': 2
'C': 1
'H': 1