猿问

按频率组织字典

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


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)

我该怎么做,以便味精按正确使用的值从顶部最常用的单词到底部最少的单词按顺序打印单词?



拉风的咖菲猫
浏览 120回答 3
3回答

小怪兽爱吃肉

从文档中:most_common([n])返回n个最常见元素的列表,以及从最常见元素到最少元素的计数。如果未指定n,则most_common()返回计数器中的所有元素。相等计数的元素是任意排序的:>>> Counter('abracadabra').most_common(3)[('a', 5), ('r', 2), ('b', 2)]您的代码可以是:from collections import Counterc = 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)

www说

一旦有了values它,就很简单:print('Word | Times Used')for e, t in collections.Counter(values).most_common(10):    print("%s|%d" % (e,t))打印类似:Word | Times Usede|4d|3a|2c|2
随时随地看视频慕课网APP

相关分类

Python
我要回答