婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > Python統(tǒng)計詞頻并繪制圖片(附完整代碼)

Python統(tǒng)計詞頻并繪制圖片(附完整代碼)

熱門標簽:ai電話機器人哪里好 ai電銷機器人源碼 長沙高頻外呼系統(tǒng)原理是什么 百度地圖標注沒有了 外呼并發(fā)線路 地圖標注審核表 西藏房產(chǎn)智能外呼系統(tǒng)要多少錢 湛江智能外呼系統(tǒng)廠家 宿遷星美防封電銷卡

效果



1 實現(xiàn)代碼

讀取txt文件:

def readText(text_file_path):
    with open(text_file_path, encoding='gbk') as f: #
        content = f.read()
    return content

得到文章的詞頻:

def getRecommondArticleKeyword(text_content,  key_word_need_num = 10, custom_words = [], stop_words =[], query_pattern = 'searchEngine'):
    '''
    :param text_content: 文本字符串
    :param key_word_need_num: 需要的關(guān)鍵詞數(shù)量
    :param custom_words: 自定義關(guān)鍵詞
    :param stop_words: 不查詢關(guān)鍵詞
    :param query_pattern:
    precision:精確模式————試圖將句子最精確地切開,適合文本分析;
    entire:全模式————把句子中所有的可以成詞的詞語都掃描出來, 速度非常快,但是不能解決歧義;
    searchEngine:搜索引擎模式————在精確模式的基礎(chǔ)上,對長詞再次切分,提高召回率,適合用于搜索引擎分詞;
    paddle模式————利用PaddlePaddle深度學習框架,訓練序列標注(雙向GRU)網(wǎng)絡(luò)模型實現(xiàn)分詞。同時支持詞性標注。
    :return:
    '''
    # jieba.enable_paddle()
    # paddle.fluid.install_check.run_check()
    if not isinstance(text_content, str):
        raise ValueError('文本字符串類型錯誤!')
    if not isinstance(key_word_need_num, int):
        raise ValueError('關(guān)鍵詞個數(shù)類型錯誤!')
    if not isinstance(custom_words, list):
        raise ValueError('自定義關(guān)鍵詞類型錯誤!')
    if not isinstance(stop_words, list):
        raise ValueError('屏蔽關(guān)鍵詞類型錯誤!')
    if not isinstance(query_pattern, str):
        raise ValueError('查詢模式類型錯誤!')

    # 添加自定義關(guān)鍵詞
    for word in custom_words:
        jieba.add_word(word)

    if query_pattern == 'searchEngine':
        key_words = jieba.cut_for_search(text_content)
    elif query_pattern == 'entire':
        key_words = jieba.cut(text_content, cut_all=True, use_paddle=True)
    elif query_pattern == 'precision':
        key_words = jieba.cut(text_content, cut_all=False, use_paddle=True)
    else:
        return []

    # print("拆分后的詞: %s" % " ".join(key_words))

    # 過濾后的關(guān)鍵詞
    stop_words = set(stop_words)
    word_count = Counter()
    for word in key_words:
        if len(word) > 1 and word not in stop_words:
            word_count[word] += 1

    # res_words = list()
    # for data in word_count.most_common(key_word_need_num):
    #     res_words.append(data[0])
    # return res_words

    return word_count

繪制圖片:

def drawWordsCloud(word_count, save_img_filePath='', img_mask_filePath=''):
    # print(word_count)
    # print(type(word_count))

    if len(img_mask_filePath) != 0:
        img_mask = np.array(Image.open(img_mask_filePath)) #打開遮罩圖片,將圖片轉(zhuǎn)換為數(shù)組
        wc = wordcloud.WordCloud(font_path='/Library/Fonts/Arial Unicode.ttf',# 設(shè)置中文字體,詞云默認字體是“DroidSansMono.ttf字體庫”,不支持中文
                                 background_color="white",  # 設(shè)置背景顏色
                                 max_words=200,  # 設(shè)置最大顯示的字數(shù)
                                 max_font_size=50,  # 設(shè)置字體最大值
                                 random_state=30,  # 設(shè)置有多少種隨機生成狀態(tài),即有多少種配色方案
                                 width=400,
                                 height=200,
                                 mask=img_mask
                                 )
    else:
        wc = wordcloud.WordCloud(font_path='/Library/Fonts/Arial Unicode.ttf',# 設(shè)置中文字體,詞云默認字體是“DroidSansMono.ttf字體庫”,不支持中文
                                 background_color="white",  # 設(shè)置背景顏色
                                 max_words=200,  # 設(shè)置最大顯示的字數(shù)
                                 max_font_size=50,  # 設(shè)置字體最大值
                                 random_state=30,  # 設(shè)置有多少種隨機生成狀態(tài),即有多少種配色方案
                                 width=400,
                                 height=200
                                 )
    # 繪圖
    wc.generate_from_frequencies(word_count)   #從字典生成詞云
    plt.imshow(wc)      #顯示詞云
    plt.axis('off')     #關(guān)閉坐標軸
    plt.show()          #顯示圖像

    # 保存圖片
    if len(save_img_filePath) != 0:
        wc.to_file(save_img_filePath)
    else:
        pass

2 完整代碼

#-*- coding : utf-8-*-
import jieba
from collections import Counter
import paddle

import wordcloud    #詞云展示庫
import matplotlib.pyplot as plt     #圖像展示庫

import time

from PIL import Image
import numpy as np

def timer(func):
    def calculateTime(*args, **kwargs):
        t = time.perf_counter()
        result = func(*args, **kwargs)
        print(f'func {func.__name__} coast time:{time.perf_counter() - t:.8f} s')
        return result
    return calculateTime

def readText(text_file_path):
    with open(text_file_path, encoding='gbk') as f: #
        content = f.read()
    return content

@timer
def getRecommondArticleKeyword(text_content,  key_word_need_num = 10, custom_words = [], stop_words =[], query_pattern = 'searchEngine'):
    '''
    :param text_content: 文本字符串
    :param key_word_need_num: 需要的關(guān)鍵詞數(shù)量
    :param custom_words: 自定義關(guān)鍵詞
    :param stop_words: 不查詢關(guān)鍵詞
    :param query_pattern:
    precision:精確模式————試圖將句子最精確地切開,適合文本分析;
    entire:全模式————把句子中所有的可以成詞的詞語都掃描出來, 速度非常快,但是不能解決歧義;
    searchEngine:搜索引擎模式————在精確模式的基礎(chǔ)上,對長詞再次切分,提高召回率,適合用于搜索引擎分詞;
    paddle模式————利用PaddlePaddle深度學習框架,訓練序列標注(雙向GRU)網(wǎng)絡(luò)模型實現(xiàn)分詞。同時支持詞性標注。
    :return:
    '''
    # jieba.enable_paddle()
    # paddle.fluid.install_check.run_check()
    if not isinstance(text_content, str):
        raise ValueError('文本字符串類型錯誤!')
    if not isinstance(key_word_need_num, int):
        raise ValueError('關(guān)鍵詞個數(shù)類型錯誤!')
    if not isinstance(custom_words, list):
        raise ValueError('自定義關(guān)鍵詞類型錯誤!')
    if not isinstance(stop_words, list):
        raise ValueError('屏蔽關(guān)鍵詞類型錯誤!')
    if not isinstance(query_pattern, str):
        raise ValueError('查詢模式類型錯誤!')

    # 添加自定義關(guān)鍵詞
    for word in custom_words:
        jieba.add_word(word)

    if query_pattern == 'searchEngine':
        key_words = jieba.cut_for_search(text_content)
    elif query_pattern == 'entire':
        key_words = jieba.cut(text_content, cut_all=True, use_paddle=True)
    elif query_pattern == 'precision':
        key_words = jieba.cut(text_content, cut_all=False, use_paddle=True)
    else:
        return []

    # print("拆分后的詞: %s" % " ".join(key_words))

    # 過濾后的關(guān)鍵詞
    stop_words = set(stop_words)
    word_count = Counter()
    for word in key_words:
        if len(word) > 1 and word not in stop_words:
            word_count[word] += 1

    # res_words = list()
    # for data in word_count.most_common(key_word_need_num):
    #     res_words.append(data[0])
    # return res_words

    return word_count

def drawWordsCloud(word_count, save_img_filePath='', img_mask_filePath=''):
    # print(word_count)
    # print(type(word_count))

    if len(img_mask_filePath) != 0:
        img_mask = np.array(Image.open(img_mask_filePath)) #打開遮罩圖片,將圖片轉(zhuǎn)換為數(shù)組
        wc = wordcloud.WordCloud(font_path='/Library/Fonts/Arial Unicode.ttf',# 設(shè)置中文字體,詞云默認字體是“DroidSansMono.ttf字體庫”,不支持中文
                                 background_color="white",  # 設(shè)置背景顏色
                                 max_words=200,  # 設(shè)置最大顯示的字數(shù)
                                 max_font_size=50,  # 設(shè)置字體最大值
                                 random_state=30,  # 設(shè)置有多少種隨機生成狀態(tài),即有多少種配色方案
                                 width=400,
                                 height=200,
                                 mask=img_mask
                                 )
    else:
        wc = wordcloud.WordCloud(font_path='/Library/Fonts/Arial Unicode.ttf',# 設(shè)置中文字體,詞云默認字體是“DroidSansMono.ttf字體庫”,不支持中文
                                 background_color="white",  # 設(shè)置背景顏色
                                 max_words=200,  # 設(shè)置最大顯示的字數(shù)
                                 max_font_size=50,  # 設(shè)置字體最大值
                                 random_state=30,  # 設(shè)置有多少種隨機生成狀態(tài),即有多少種配色方案
                                 width=400,
                                 height=200
                                 )
    # 繪圖
    wc.generate_from_frequencies(word_count)   #從字典生成詞云
    plt.imshow(wc)      #顯示詞云
    plt.axis('off')     #關(guān)閉坐標軸
    plt.show()          #顯示圖像

    # 保存圖片
    if len(save_img_filePath) != 0:
        wc.to_file(save_img_filePath)
    else:
        pass



if __name__ == '__main__':
    pass
    # /Users/mac/Downloads/work/retailSoftware/公司項目/test.txt
    text_file_path = "/Users/mac/Downloads/電子書/編程思想/相約星期二/相約星期二.txt"
    # text_file_path = "/Users/mac/Downloads/work/retailSoftware/公司項目/test3.txt"
    text_content = readText(text_file_path)
    # print(text_content)
    # print(JNI_API_getRecommondArticleKeyword(text_content))
    img_mask_filePath = '/Users/mac/Desktop/截屏2021-08-20 下午4.02.10.png'
    img_save_filePath = '/Users/mac/Downloads/test9.png'
    drawWordsCloud(getRecommondArticleKeyword(text_content), img_save_filePath, img_mask_filePath)


到此這篇關(guān)于Python統(tǒng)計詞頻并繪制圖片(附完整代碼)的文章就介紹到這了,更多相關(guān)Python統(tǒng)計詞頻繪制圖片內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • python中Matplotlib繪制直線的實例代碼
  • python一繪制元二次方程曲線的實例分析
  • python基于turtle繪制幾何圖形
  • 淺談Python pygame繪制機制
  • 利用Python快速繪制海報地圖

標簽:寧夏 林芝 南平 盤錦 漯河 海南 大同 普洱

巨人網(wǎng)絡(luò)通訊聲明:本文標題《Python統(tǒng)計詞頻并繪制圖片(附完整代碼)》,本文關(guān)鍵詞  Python,統(tǒng)計,詞頻,并,繪制,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Python統(tǒng)計詞頻并繪制圖片(附完整代碼)》相關(guān)的同類信息!
  • 本頁收集關(guān)于Python統(tǒng)計詞頻并繪制圖片(附完整代碼)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    欧美精选在线播放| 亚洲国产精品成人综合| 懂色av噜噜一区二区三区av| 日本系列欧美系列| 亚洲成人av福利| 亚洲无线码一区二区三区| 一区二区三区精品久久久| 精品一区二区三区久久久| 久久精品国产99国产| 裸体健美xxxx欧美裸体表演| 国产一区二区三区免费看 | 国产视频在线观看一区二区三区 | 久久99精品久久久久久动态图 | 日韩欧美美女一区二区三区| 日韩三级精品电影久久久| 欧美成人福利视频| 国产嫩草影院久久久久| 亚洲天堂网中文字| 天天操天天综合网| 国产一本一道久久香蕉| 国产v综合v亚洲欧| 99久久综合狠狠综合久久| 欧美日韩一级黄| 久久夜色精品国产噜噜av| 国产精品一二三区| 在线这里只有精品| 精品盗摄一区二区三区| 欧美激情一区在线| 亚洲国产视频网站| 国产精品亚洲人在线观看| 成av人片一区二区| 日韩欧美aaaaaa| 成人免费在线播放视频| 亚洲午夜视频在线观看| 国产成人午夜精品5599 | 极品美女销魂一区二区三区免费| 国产91对白在线观看九色| 欧美主播一区二区三区| 日韩精品一区二区三区四区| 亚洲免费伊人电影| 韩国女主播成人在线观看| 91天堂素人约啪| 久久―日本道色综合久久| 亚洲国产精品一区二区www在线| 国产精品亚洲一区二区三区在线| 欧美丰满一区二区免费视频| 中文字幕制服丝袜成人av| 国产91精品一区二区麻豆网站| 久久精品免视看| 亚洲成人一区二区在线观看| 国产成人夜色高潮福利影视| 日韩欧美国产一区二区三区 | 日韩av成人高清| 99国产精品国产精品毛片| 欧美成人女星排行榜| 亚洲国产婷婷综合在线精品| 91麻豆6部合集magnet| 中文在线一区二区| 国产在线精品一区二区不卡了| 欧美精品免费视频| 亚洲精品国产精华液| 成人激情图片网| 久久久久久99精品| 国产精品一区二区久久不卡| 日韩视频免费直播| 蜜桃精品视频在线| 91精品国模一区二区三区| 夜夜爽夜夜爽精品视频| 色婷婷综合久久久| 一区二区三区中文在线观看| 99riav久久精品riav| 国产亚洲福利社区一区| 亚洲国产高清在线观看视频| 成人午夜电影网站| 欧美哺乳videos| 国产美女精品在线| 久久精品夜色噜噜亚洲aⅴ| 黄页视频在线91| 中文字幕不卡一区| 色8久久人人97超碰香蕉987| 亚洲电影视频在线| 欧美日韩日日夜夜| 久久精品国产网站| 久久久久国产精品麻豆| 不卡视频一二三四| 亚洲综合激情另类小说区| 777午夜精品免费视频| 麻豆一区二区在线| 中文一区二区在线观看| 91免费在线看| 日韩专区中文字幕一区二区| 欧美精品一区男女天堂| 成人免费高清在线| 亚洲资源在线观看| 亚洲精品在线一区二区| 99久久精品免费精品国产| 亚洲成av人片一区二区梦乃 | 在线中文字幕不卡| 久久精品国产一区二区| 亚洲欧美一区二区三区国产精品| 欧美日韩综合在线| 国产精品1区2区3区| 亚洲视频精选在线| 欧美第一区第二区| 91久久香蕉国产日韩欧美9色| 婷婷综合另类小说色区| 国产女人aaa级久久久级| 欧美视频一区二| 国产成人亚洲综合a∨猫咪| 亚洲电影激情视频网站| 国产三级欧美三级日产三级99 | 中文在线资源观看网站视频免费不卡| 91麻豆自制传媒国产之光| 全国精品久久少妇| 亚洲黄一区二区三区| 欧美大片一区二区| 欧美日韩三级在线| 色综合久久99| 国产美女在线精品| 午夜av一区二区| 亚洲三级视频在线观看| 2022国产精品视频| 日韩一区二区电影| 91福利国产成人精品照片| 粉嫩av一区二区三区粉嫩| 蜜桃一区二区三区在线观看| 亚洲一区二区三区四区在线观看 | 亚洲第一成人在线| 国产精品进线69影院| 久久久综合精品| 日韩一级完整毛片| 欧美一区二区三级| 欧美男男青年gay1069videost| 99精品国产视频| www.亚洲精品| 成人午夜视频免费看| 国产高清在线精品| 国产综合色精品一区二区三区| 视频一区免费在线观看| 午夜影院久久久| 亚洲成人一区二区| 午夜av区久久| 青青青伊人色综合久久| 日韩福利视频导航| 日韩av在线播放中文字幕| 午夜精彩视频在线观看不卡| 午夜视频在线观看一区二区| 午夜激情一区二区三区| 日韩二区在线观看| 久久成人av少妇免费| 精品系列免费在线观看| 国产一区二区0| 成人免费三级在线| 99久久伊人精品| 欧美午夜影院一区| 欧美伦理视频网站| 欧美精品一区二区在线播放| 国产亚洲va综合人人澡精品| 国产精品人妖ts系列视频| 中文字幕一区二区在线播放| 一区二区在线观看免费| 午夜精品福利一区二区三区蜜桃| 日韩高清国产一区在线| 国产精品77777竹菊影视小说| 成人成人成人在线视频| 日本精品裸体写真集在线观看| 777午夜精品免费视频| 久久亚区不卡日本| 亚洲天天做日日做天天谢日日欢 | 成人免费视频网站在线观看| 91丨国产丨九色丨pron| 69久久99精品久久久久婷婷| 久久人人97超碰com| 亚洲欧洲综合另类| 日本欧美久久久久免费播放网| 国产一区二区三区精品欧美日韩一区二区三区 | 国产精品成人免费| 午夜欧美一区二区三区在线播放| 看片的网站亚洲| 成人黄色777网| 欧美一区二区视频在线观看| 中文在线一区二区| 毛片av一区二区| 在线亚洲一区观看| 国产肉丝袜一区二区| 亚洲午夜一区二区三区| 国产aⅴ综合色| 91精品国产福利在线观看| **性色生活片久久毛片| 久久se精品一区二区| 91久久精品一区二区三| 精品国产凹凸成av人导航| 夜夜夜精品看看| 成人久久视频在线观看| 日韩欧美成人午夜| 亚洲chinese男男1069| 91美女福利视频| 国产精品久久久久影院| 国模娜娜一区二区三区| 7777精品伊人久久久大香线蕉 |