python统计txt文件中不同文字出现的次数_Python 练习册 6-统计文本文件中单词的次数...

目标

你有一个目录,放了你一个月的日记,都是 txt,为了避免分词的问题,假设内容都是英文,请统计出你认为每篇日记最重要的词。

解决方案

该题目代码如下:

#!/usr/bin/env python3

# -*- coding: utf-8 -*-

"""

你有一个目录,放了你一个月的日记,都是 txt,为了避免分词的问题,假设内容都是英文,请统计出你认为每篇日记最重要的词。

"""

import os

import re

def get_file_list(path):

"""

遍历文件目录,返回文件路径列表

"""

file_list = []

for root, dirs, files in os.walk(path):

for file in files:

if file.lower().endswith('txt'):

file_list.append(os.path.join(root,file))

return file_list

def find_keyword(file_path):

"""

根据文件路径,找到文件中的关键字

:param file_path:

:return:

"""

keywords = {}

file_name = os.path.basename(file_path)

with open(file_path, encoding='utf-8') as file:

text = file.read()

word_list = re.findall(r'[a-zA-Z]+', text.lower())

for word in word_list:

if word in keywords:

keywords[word] += 1

else:

keywords[word] = 1

keywords_sorted = sorted(keywords.items(), key=lambda d: d[1])

return file_name, keywords_sorted

for path in get_file_list(os.getcwd()):

name, results = find_keyword(path)

print(u"在 %s 文件中,%s 为关键词,共出现了 %s 次" % (name, results[-1][0], results[-1][1]))

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值