3 回答
data:image/s3,"s3://crabby-images/8e46f/8e46f7ca2ff4b91773436f0c0b8784a7749d18cf" alt="?"
TA贡献1788条经验 获得超4个赞
您必须在word_freq.items()这里使用:
lis = sorted(word_freq.items(), key = lambda x:x[1], reverse = True)
for word,freq in lis:
print ("%-10s %d" % (word, freq))
不要list用作变量名。
data:image/s3,"s3://crabby-images/8b56d/8b56d893cbd2efae97c859c5f5a1e67777b54f9b" alt="?"
TA贡献1876条经验 获得超5个赞
使用collections.Counter有助于对事物进行计数,并使用withstatement来帮助打开(和关闭)文件。
import collections
with open('C:\\Temp\\Test2.txt', 'r') as f:
text = f.read()
word_freq = collections.Counter(text.lower().split())
for word, freq in word_freq.most_common():
print ("%-10s %d" % (word, freq))
data:image/s3,"s3://crabby-images/a6e4a/a6e4a76d83eb33e32a06873b0c20d5acb6d326c8" alt="?"
TA贡献1951条经验 获得超3个赞
看一下集合。
>>> wordlist = ['foo', 'bar', 'foo', 'baz']
>>> import collections
>>> counter = collections.Counter(wordlist)
>>> counter.most_common()
[('foo', 2), ('baz', 1), ('bar', 1)]
添加回答
举报