91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Python怎么使用tf-idf算法計算文檔關鍵字權重并生成詞云

發布時間:2023-03-16 14:30:29 來源:億速云 閱讀:138 作者:iii 欄目:開發技術

本文小編為大家詳細介紹“Python怎么使用tf-idf算法計算文檔關鍵字權重并生成詞云”,內容詳細,步驟清晰,細節處理妥當,希望這篇“Python怎么使用tf-idf算法計算文檔關鍵字權重并生成詞云”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學習新知識吧。

1. 根據tf-idf計算一個文檔的關鍵詞或者短語:

代碼如下:

注意需要安裝pip install sklean

from re import split
from jieba.posseg import dt
from sklearn.feature_extraction.text import TfidfVectorizer
from collections import Counter
from time import time
import jieba


#pip install sklean


FLAGS = set('a an b f i j l n nr nrfg nrt ns nt nz s t v vi vn z eng'.split())

def cut(text):
    for sentence in split('[^a-zA-Z0-9\u4e00-\u9fa5]+', text.strip()):
        for w in dt.cut(sentence):
            if len(w.word) > 2 and w.flag in FLAGS:
                yield w.word

class TFIDF:
    def __init__(self, idf):
        self.idf = idf

    @classmethod
    def train(cls, texts):
        model = TfidfVectorizer(tokenizer=cut)
        model.fit(texts)
        idf = {w: model.idf_[i] for w, i in model.vocabulary_.items()}
        return cls(idf)

    def get_idf(self, word):
        return self.idf.get(word, max(self.idf.values()))

    def extract(self, text, top_n=10):
        counter = Counter()
        for w in cut(text):
            counter[w] += self.get_idf(w)
        #return [i[0:2] for i in counter.most_common(top_n)]
        return [i[0] for i in counter.most_common(top_n)]


if __name__ == '__main__':
    t0 = time()
    with open('./nlp-homework.txt', encoding='utf-8')as f:
        _texts = f.read().strip().split('\n')
        # print(_texts)
    tfidf = TFIDF.train(_texts)
    # print(_texts)
    for _text in _texts:
        seq_list=jieba.cut(_text,cut_all=True)  #全模式
        # seq_list=jieba.cut(_text,cut_all=False)  #精確模式
        # seq_list=jieba.cut_for_search(_text,)    #搜索引擎模式
        # print(list(seq_list))
        print(tfidf.extract(_text))
        with open('./resultciyun.txt','a+', encoding='utf-8') as g:
            for i in tfidf.extract(_text):
                g.write(str(i) + " ")
    print(time() - t0)

2. 生成詞云:

代碼如下:

  • 注意需要安裝pip install wordcloud

  • 以及為了保證中文字體正常顯示,需要下載SimSun.ttf字體,并且將這個字體包也放在和程序相同的目錄下;

from wordcloud import WordCloud
filename = "resultciyun.txt"
with open(filename) as f:
 resultciyun = f.read()

wordcloud = WordCloud(font_path="simsun.ttf").generate(resultciyun)
# %pylab inline
import matplotlib.pyplot as plt
plt.imshow(wordcloud, interpolation='bilinear')
plt.axis("off")
plt.show()

3 最后詞云的圖片

Python怎么使用tf-idf算法計算文檔關鍵字權重并生成詞云

讀到這里,這篇“Python怎么使用tf-idf算法計算文檔關鍵字權重并生成詞云”文章已經介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領會,如果想了解更多相關內容的文章,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

贡觉县| 新巴尔虎右旗| 象州县| 连江县| 巨野县| 即墨市| 兴山县| 扎鲁特旗| 莆田市| 高尔夫| 东光县| 达州市| 汨罗市| 斗六市| 上栗县| 威信县| 突泉县| 松溪县| 信宜市| 蒲江县| 台南市| 屯留县| 江阴市| 连江县| 大丰市| 高安市| 呼玛县| 呼和浩特市| 江山市| 玉龙| 富源县| 潮安县| 肥城市| 大同市| 安阳县| 随州市| 天气| 康马县| 彰武县| 静宁县| 漳浦县|