Python利用结巴模块统计《水浒传》词频

2021-05-21 16:48:26 浏览数 (1)

中文分词是中文文本处理的一个基础性工作,结巴分词利用进行中文分词。其基本实现原理有三点:

  1. 基于Trie树结构实现高效的词图扫描,生成句子中汉字所有可能成词情况所构成的有向无环图(DAG)
  2. 采用了动态规划查找最大概率路径, 找出基于词频的最大切分组合
  3. 对于未登录词,采用了基于汉字成词能力的HMM模型,使用了Viterbi算法

下面利用结巴分词队水浒传的词频进行了统计

代码:

Python

代码语言:txt复制
#!/usr/bin/python    
# -*- coding:utf-8 -*-    
 
import sys
 
import jieba
import jieba.analyse
import xlwt  # 写入Excel表的库
 
if __name__ == "__main__":
 
    wbk = xlwt.Workbook(encoding='ascii')
    sheet = wbk.add_sheet("wordCount")  # Excel单元格名字
    word_lst = []
    key_list = []
    for line in open('C:\Users\dell\desktop\1.txt'):  # 1.txt是需要分词统计的文档
        try:
            item = line.strip('nr').split('t')  # 制表格切分
            # print(item)
            tags = jieba.analyse.extract_tags(item[0])  # jieba分词
            for t in tags:
                word_lst.append(t)
        except:
            pass
 
    word_dict = {}
    with open("wordCount.txt", 'w') as wf2:  # 打开文件
 
        for item in word_lst:
            if item not in word_dict:  # 统计数量
                word_dict[item] = 1
            else:
                word_dict[item]  = 1
 
        orderList = list(word_dict.values())
        orderList.sort(reverse=True)
        # print orderList  
        for i in range(len(orderList)):
            for key in word_dict:
                if word_dict[key] == orderList[i]:
                    wf2.write(key   ' '   str(word_dict[key])   'n')  # 写入txt文档
                    key_list.append(key)
                    word_dict[key] = 0
 
    for i in range(len(key_list)):
        sheet.write(i, 1, label=orderList[i])
        sheet.write(i, 0, label=key_list[i])
    wbk.save('wordCount.xls')  # 保存为 wordCount.xls文件

结果:

如果数据有误那就是水浒传txt文件被修改过了,这就别怪我咯。

0 人点赞