Python快速生成词云

本文介绍了Python使用wordcloud模块生成词云的详细过程,包括安装wordcloud的解决方法和如何创建带有图片背景的词云,旨在帮助NLP研究者进行数据可视化。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Python快速生成词云

今天是2018年10月27号,小亮继续着自己深度学习与自然语言处理的打怪升级之路。今天给大家介绍一下Python快速生成词云的实现,在这里与大家交流一下!

笔者信息:Next_Legend QQ:1219154092 机器学习 自然语言处理 计算机视觉 深度学习
小亮的博客:https://legendtianjin.github.io/NextLegend.github.io/ ——2018.10.27 于北洋

一、词云初衷

        小亮今天跟大家介绍用 wrodcloud 模块来生成词云,因为小亮从事NLP方向的,我们面对的基本数据是文本形式,所以这个词云有必要学习一下,一是为了更好地向别人展示自己的研究工作,二是通过可视化,直观形象展示结果。下面,小亮先放上一张生成的词云照片,让大家感受一下效果图:

在这里插入图片描述

二、wordcloud的安装

        对于安装wordcloud模块,我们一般都是通过Pycharm或者PIP安装的,但是在安装wordcloud时会提示错误,如下:

在这里插入图片描述

       这里的解决方法是直接访问下面的网址,根据你的电脑和py版本下载对应的whl文件https://www.lfd.uci.edu/~gohlke/pythonlibs/#wordcloud

在这里插入图片描述

       下载完成后,把whl文件放在pip路径下,输入安装的代码,记住代码的whl文件名一定是适合你的文件名,基本就安装成功啦!
       小亮在这里是通过Pycharm安装的,步骤如下:
       (1) Pycharm快捷键 Ctrl + Alt + S,打开Setting界面,点击右边的+

在这里插入图片描述

       (2) 搜索wordcloud包,点击左下角安装

在这里插入图片描述

       (3) 稍等几分钟或者十几秒就安装好啦,然后写一个脚本检验一下是否安装成功。

在这里插入图片描述

三、wordcloud生成词云

        (1)直接生成
#coding:utf-8
from wordcloud import WordCloud
import matplotlib.pyplot as plt  #绘制图像的模块
import  jieba                    #jieba分词


path_txt='G:\Code\Python_Learn\Study_Tensorflow_2018\\venv\\2018接的小项目\Python词云\\test1.txt'
f = open(path_txt,'r',encoding='UTF-8').read()

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

wordcloud = WordCloud(
   #设置字体,不然会出现口字乱码,文字的路径是电脑的字体一般路径,可以换成别的
   font_path="G:\Code\Python_Learn\Study_Tensorflow_2018\\venv\\2018接的小项目\Python词云\simfang.ttf",
   #设置了背景,宽高
   background_color="white",width=1000,height=880).generate(cut_text)

plt.imshow(wordcloud, interpolation="bilinear")
plt.axis("off")
plt.show()
       运行结果

在这里插入图片描述

        (2)给词云加上图片背景,代码如下:生成特定格式的词云
#coding:utf-8
from PIL import Image
from wordcloud import WordCloud, ImageColorGenerator
import matplotlib.pyplot as plt
import numpy as np
import jieba



def GetWordCloud():
    path_txt = 'G:\Code\Python_Learn\Study_Tensorflow_2018\\venv\\2018接的小项目\Python词云\\test1.txt'
    path_img = "G:\Code\Python_Learn\Study_Tensorflow_2018\\venv\\2018接的小项目\Python词云\\001.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="G:\Code\Python_Learn\Study_Tensorflow_2018\\venv\\2018接的小项目\Python词云\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()
       运行结果

在这里插入图片描述
在这里插入图片描述

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值