第三次课后作业

学号:2017********7047

姓名:车功明

码云地址:https://gitee.com/f-q/word_frequency.git

from string import punctuation
def process_file(dst):
try:
f = open(dst)
except IOError as s:
print (s)
return None
try:
bvffer = f.read()
except:
print ("Read File Error!")
return None
f.close()
return bvffer
打开、读取文档并将文档存储到buffer里面,执行完毕后关闭文档
def process_buffer(bvffer):
if bvffer:
word_freq = {}
for item in bvffer.strip().split():
word = item.strip(punctuation+' ')
if word in word_fred:
word_freq[word] += 1
else:
word_freq[word] = 1
return word_freq
将buffer内的数据进行切片,去掉符号空格,用for循环进行统计,将统计数据存储在word_freq并返回值
def output_result(word_freq):
if word_freq:
sorted_word_freq = sorted(word_freq.items(), key=lambda v: v[1], reverse=True)
for item in sorted_word_freq[:10]:
print (item)
将统计好的数据进行排序并输出前十个数据
if __name__ == "__main__":
import argparse
parser = argparse.ArgumentParser()
parser.add_argument('dst')
args = parser.parse_args()
dst = args.dst
bvffer = process_file(dst)
word_freq = process_buffer(bvffer)
output_result(word_freq)
程序运行命令
程序运行结果


改进前
总时长

  找到的执行时间最长,执行次数最多的代码

 

  改进后:

  总时长:

  找到的执行时间最长,执行次数最多的代码:

总结与反思:通过这次作业,我学会了用git上传文件分支,也学会了用python找到重复的单词,收获颇丰

转载于:https://www.cnblogs.com/c-1234/p/10646993.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值