首頁 >後端開發 >Python教學 >Python如何產生詞雲的方法

Python如何產生詞雲的方法

不言
不言原創
2018-06-02 14:40:283208瀏覽

這篇文章主要介紹了Python如何產生詞雲的方法,有著一定的參考價值,現在分享給大家,有需要的朋友可以參考一下

前言

今天教大家用wrodcloud模組來產生詞雲,我讀了一篇小說並產生了詞雲,先看一下效果圖:

效果圖一:

效果圖二:

根據效果圖分析的還是比較準確的,小說中的主角就是“程理”,所以出現次數最多。圖中有兩種模式,一種是預設的模式,另一種是自己加入圖片作為背景。下面我就帶大家一起來學習怎樣去生成詞雲!

wordcloud的安裝

對新人來說安裝wordcloud模組就是一大關,我們一般都是透過Pycharm或PIP安裝的,但在安裝wordcloud時會提示錯誤,如下:

我的解決方法是直接存取下面的網址,根據你的電腦和py版本下載對應的whl檔案

下載完成後,把whl檔放在pip路徑下,輸入下面的程式碼,記住程式碼的whl檔名一定是適合你的檔名,我只是舉例:

pip install wordcloud-1.4.1-cp36-cp36m-win32.whl

運行後會顯示安裝成功

wordcloud的簡單用法

wordcloud的基本方法,看原始碼如下:

每個參數大家應該一看就明白,另外wordcloud還有幾個其他方法,像是fit_words,generate(text),to_file(filename)等等都是非常好理解的。

wordcloud產生詞雲

效果圖一的程式碼:

from wordcloud import WordCloud
import matplotlib.pyplot as plt #绘制图像的模块
import jieba     #jieba分词

path_txt='C://Users/Administrator/Desktop/all.txt'
f = open(path_txt,'r',encoding='UTF-8').read()

# 结巴分词,生成字符串,wordcloud无法直接生成正确的中文词云
cut_text = " ".join(jieba.cut(f))

wordcloud = WordCloud(
 #设置字体,不然会出现口字乱码,文字的路径是电脑的字体一般路径,可以换成别的
 font_path="C:/Windows/Fonts/simfang.ttf",
 #设置了背景,宽高
 background_color="white",width=1000,height=880).generate(cut_text)

plt.imshow(wordcloud, interpolation="bilinear")
plt.axis("off")
plt.show()

運行後:

效果圖二,為詞雲加上圖片背景,程式碼如下:

from PIL import Image
from wordcloud import WordCloud, ImageColorGenerator
import matplotlib.pyplot as plt
import numpy as np
import jieba
def GetWordCloud():
 path_txt = 'C://Users/Administrator/Desktop/all.txt'
 path_img = "C://Users/Administrator/Desktop/timg.jpg"
 f = open(path_txt, 'r', encoding='UTF-8').read()
 background_image = np.array(Image.open(path_img))
 # 结巴分词,生成字符串,如果不通过分词,无法直接生成正确的中文词云,感兴趣的朋友可以去查一下,有多种分词模式
 #Python join() 方法用于将序列中的元素以指定的字符连接生成一个新的字符串。
 cut_text = " ".join(jieba.cut(f))

 wordcloud = WordCloud(
  # 设置字体,不然会出现口字乱码,文字的路径是电脑的字体一般路径,可以换成别的
  font_path="C:/Windows/Fonts/simfang.ttf",
  background_color="white",
  # mask参数=图片背景,必须要写上,另外有mask参数再设定宽高是无效的
  mask=background_image).generate(cut_text)
 # 生成颜色值
 image_colors = ImageColorGenerator(background_image)
 # 下面代码表示显示图片
 plt.imshow(wordcloud.recolor(color_func=image_colors), interpolation="bilinear")
 plt.axis("off")
 plt.show()

if __name__ == '__main__':
 GetWordCloud()

運行後:

相關推薦:

Python產生任意範圍任意精度的隨機數的方法

#

以上是Python如何產生詞雲的方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn