# excel转变为文本 defexcel2txt(file_path): data = xlrd.open_workbook( file_path, encoding_override='utf-8') # 打开Excel文件读取数据 sh = data.sheet_by_name("Sheet1") # 通过工作簿名称获取 n = 0 i = 0 file = open("temp.txt", "w") for n in range(sh.nrows): for i in range(sh.ncols): text = sh.cell_value(n, i).encode('utf-8') file.write(text) file.write('\n')
# 结巴词频分析 defjieba_analyse(): if __name__ == "__main__": wbk = xlwt.Workbook(encoding='ascii') sheet = wbk.add_sheet("wordCount") # Excel单元格名字 word_lst = [] key_list = [] for line in open('temp.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 notin 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]: # 写入txt文档 wf2.write(key + ' ' + str(word_dict[key]) + '\n') 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文件