您好,登錄后才能下訂單哦!
這篇文章主要介紹“Python基于詞頻排序如何實現快速挖掘關鍵詞”的相關知識,小編通過實際案例向大家展示操作過程,操作方法簡單快捷,實用性強,希望這篇“Python基于詞頻排序如何實現快速挖掘關鍵詞”文章能幫助大家解決問題。
這是所有的代碼
from collections import defaultdict import jieba.posseg as jp with open('keyword.txt','r',encoding='utf-8') as file: keyword_list = file.read().split('\n') not_flag = set(['w','x','y','z','un','m']) not_word = set(['的','是','有','啊','呢','么','好']) keyword_split = dict() word_count = defaultdict(int) for keyword in keyword_list: word_set = set() for word,flag in jp.cut(keyword): if flag in not_flag: continue if word in not_word: continue if word == 'pdf' or word == 'PDF': continue word_count[word] += 1 word_set.add(word) keyword_split[keyword] = word_set id_keyword_list = defaultdict(list) id_count = defaultdict(int) for keyword,word_set in keyword_split.items(): word_sort = dict() for word in word_set: word_sort[word] = word_count[word] word_sort = sorted(word_sort.items(),key=lambda x:x[1],reverse=True) word_id = ','.join([word for word,count in word_sort[0:3]]) id_keyword_list[word_id] += [keyword] id_count[word_id] += 1 result = [] id_count = sorted(id_count.items(),key=lambda x:x[1],reverse=True) for word_id,count in id_count: if count < 3: continue for keyword in id_keyword_list[word_id]: result.append('%s\t%s' % (keyword,word_id)) result.append('') with open('result.txt','wb') as file: file.write('\n'.join(result).encode('utf-8'))
keyword.txt
如下圖:
有50萬的關于pdf的關鍵詞數據
最后的輸出result.txt
就是將里面的含有關鍵詞相同的句子統一輸出出來:
這里會將一個句子的3個關鍵詞輸出出來 關鍵詞是根據詞頻排序的。
最后將所有關鍵詞一樣的句子組合在一起,就可以知道這些句子表達的意思大致一致
keyword_list
是從keyword.txt讀取到的所有的句子
not_flag
是要排除的標記,不統計這些標記
not_word
是要排除的單詞,不統計這些單詞
keyword_split
是句子對應到他的所有單詞的字典,key是句子,value是他的所有單詞的集合
word_count
是所有的拆分后的單詞的次數的字典,key是單詞,value是單詞出現的次數
id_keyword_list
是一個字典,它的key是一個字符串 value是列表
id_count
是一個字典,它的key是一個字符串,value是int
最后對id_count處理 將結果輸出出來
id_count = sorted(id_count.items(), key=lambda x: x[1], reverse=True) for word_id, count in id_count: if count < 3: continue for keyword in id_keyword_list[word_id]: result.append('%s\t%s' % (keyword, word_id)) result.append('')
關于“Python基于詞頻排序如何實現快速挖掘關鍵詞”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識,可以關注億速云行業資訊頻道,小編每天都會為大家更新不同的知識點。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。