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

您所在的位置:网站首页 python分词统计词频 Python利用结巴模块统计《水浒传》词频 – OmegaXYZ

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

2023-03-22 04:26| 来源: 网络整理| 查看: 265

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

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

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

代码:

Python 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748 #!/usr/bin/python    # -*- coding:utf-8 -*-     import sys import jiebaimport jieba.analyseimport 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('\n\r').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文件被修改过了,这就别怪我咯。



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3