python学习--记词器程序

本文通过Python脚本展示了如何统计文本文件中的单词出现频率,并按频率从高到低排列输出前十个最常见的单词。
#!/usr/bin/env python3
# -*- coding: utf-8 -*-

#CalHamlet.py
def getText():
    txt = open("install.sh", "r").read() #读取整个文件
    txt = txt.lower()                    #大写全部转成小写
    for ch in '!"\'.,#$%&()*+-/:;<=>?@[\\]^_`{|}~':
        txt = txt.replace(ch, " ")       #特殊字符全用空格替代
    return txt                           #返回文件

hamletTxt = getText() #调用处理函数
words = hamletTxt.split() #取消掉所有空格,放入到列表words中
#print(words)
counts = {}
for word in words:
    counts[word] = counts.get(word,0) + 1 #将列表转换成字典,键值用键的个数代替
#print(counts) 
#    print(counts[word])
items = list(counts.items())   #将字典转换为列表。
#print(items)
items.sort(key = lambda x:x[1], reverse = True) #以第2列进行排序
for i in range(10):
    word, count = items[i]
    print("{0:<10} {1:>5}".format(word, count))

 

转载于:https://www.cnblogs.com/hayden1106/p/7839395.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值