2

我为最常用的单词创建了一个字典并获得了前十名。我需要对列表进行排序,这应该是有序的。如果不列出我不能使用的清单,我就无法做到这一点。这是我的代码。我离开了字典无法排序,但我仍然需要帮助。

most_used_words = Counter()
zewDict = Counter(most_used_words).most_common(10)
newDict = dict(zewDict)
keys = newDict.keys()
values = newDict.values()
msg = ('Here is your breakdown of your most used words: \n\n'
       'Word | Times Used'
       '\n:--:|:--:'
       '\n' + str(keys[0]).capitalize() + '|' + str(values[0]) +
       '\n' + str(keys[1]).capitalize() + '|' + str(values[1]) +
       '\n' + str(keys[2]).capitalize() + '|' + str(values[2]) +
       '\n' + str(keys[3]).capitalize() + '|' + str(values[3]) +
       '\n' + str(keys[4]).capitalize() + '|' + str(values[4]) +
       '\n' + str(keys[5]).capitalize() + '|' + str(values[5]) +
       '\n' + str(keys[6]).capitalize() + '|' + str(values[6]) +
       '\n' + str(keys[7]).capitalize() + '|' + str(values[7]) +
       '\n' + str(keys[8]).capitalize() + '|' + str(values[8]) +
       '\n' + str(keys[9]).capitalize() + '|' + str(values[9]))
r.send_message(user, 'Most Used Words', msg)

我将如何做到这一点,以便味精按从顶部最常用的单词到底部最少的顺序打印单词,并为该单词提供正确的值?

编辑:我知道字典不能自行排序,所以我可以以某种方式解决这个问题吗?

4

3 回答 3

4

一旦你有了values它,它就像这样简单:

print('Word | Times Used')
for e, t in collections.Counter(values).most_common(10):
    print("%s|%d" % (e,t))

打印类似:

Word | Times Used
e|4
d|3
a|2
c|2
于 2013-05-27T06:48:17.840 回答
3

文档most_common([n])

返回 n 个最常见元素的列表及其从最常见到最少的计数。如果未指定 n,most_common() 返回计数器中的所有元素。具有相同计数的元素是任意排序的:

>>> Counter('abracadabra').most_common(3)
[('a', 5), ('r', 2), ('b', 2)]

您的代码可以是:

from collections import Counter
c = Counter(most_used_words)
msg = "Here is your breakdown of your most used words:\n\nWords | Times Used\n:--:|:--:\n"
msg += '\n'.join('%s|%s' % (k.capitalize(), v) for (k, v) in c.most_common(10))
r.send_message(user, 'Most Used Words', msg)
于 2013-05-27T06:42:52.107 回答
2
import operator
newDict = dict(zewDict)

sorted_newDict = sorted(newDict.iteritems(), key=operator.itemgetter(1))
msg = ''
for key, value in sorted_newDict:
  msg.append('\n' + str(key).capitalize() + '|' + str(value))

这将按字典值排序。如果您希望以其他顺序添加reverse=Truesorted().

于 2013-05-27T06:42:37.253 回答