前两天,班上同学写论文,需要将很多篇论文题目按照中文的习惯分词并统计每个词出现的频率。
让我帮她实现这个功能,我在网上查了之后发现jIEba这个库还挺不错的。
运行环境:
安装python2.7.13:https://www.python.org/downloads/release/python-2713/ 安装jIEba:pip install jIEba 安装xlwt:pip install xlwt具体代码如下:
#!/usr/bin/python # -*- Coding:utf-8 -*- import sys reload(sys) sys.setdefaultencoding('utf-8') 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('1.txt'):#1.txt是需要分词统计的文档 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) 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,label = key_List[i]) wbk.save('wordCount.xls') #保存为 wordCount.xls文件
1.txt是你需要分词统计的文本内容,最后会生成wordCount.txt和wordCount.xls两个文件。下图是最后结果
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程小技巧。
您可能感兴趣的文章:用python结合jieba和wordcloud实现词云效果浅谈python jieba分词模块的基本用法python使用jieba实现中文分词去停用词方法示例 总结以上是内存溢出为你收集整理的python jieba分词并统计词频后输出结果到Excel和txt文档方法全部内容,希望文章能够帮你解决python jieba分词并统计词频后输出结果到Excel和txt文档方法所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)