python中用来绘制词云的第三方库_一步一步教你如何用Python做词云

前言

在大数据时代,你竟然会在网上看到的词云,例如这样的。

Python学习资料或者需要代码、视频加Python学习群:960410445

看到之后你是什么感觉?想不想自己做一个?

如果你的答案是正确的,那就不要拖延了,现在我们就开始,做一个词云分析图,Python是一个当下很流行的编程语言,你不仅可以用它做数据分析和可视化,还能用来做网站、爬取数据、做数学题、写脚本替你偷懒……

如果你之前没有编程基础,没关系。希望你不要限于浏览,而是亲自动手尝试一番。到完成的那一步,你不仅可以做出第一张词云图,而且这还将是你的第一个有用的编程作品。

安装 wordcloud库

请确保你的python环境没有问题,我用的开发工具是VsCode,首先你要在Python扩展中安装python开发环境(当然,这不是为你的windows安装python)

那么你还需要安装所需要的第三方库,那么在VSCode中并没有PyCharm那么专业,这里需要获得你自己的Python脚本位置。

我们可以发现里面有一个名为pip.exe文件,这个文件就是python官方给我们去安装python第三方库的一个程序,那么我们可以在VsCode的终端中就可以去通过它,这也是我们为什么要获取python安装位置的根本原因。

例如我们安装WordCloud,我们的操作如下:

pipinstall WordCloud

数据

这个时候我们就要开始Code了,我们一定需要数据,这里我自己找了一个绕口令,内容如下:

Betty Botter bought some butter but she said the butter's bitter. If I put it in my batter it will make my batter bitter. So, she bought some better butter, better than the bitter butter and she put it in her batter and her batter was not bitter. So 'twas good that Betty Botter bought some better butter.

翻译: 贝蒂·波特买牛油, 可她说:“牛油是苦的。 不过加上一点好牛油—— 可以使苦牛油更好点。” 于是她买了一点牛油, 比苦牛油好点的牛油。 掺了之后苦牛油真的变的好多了。 所以这就是贝蒂·波特买的一点比苦牛油好点的牛油。

我把其中的文字存储成了一个文本,叫做minister.txt。

Code

python做词云呢,需要导入的包有wordcloud和PIL,其中PIL(Python Image Library)是python平台图像处理标准库,功能是真的强大。首先需要读取文件 。

首先我们要读取我们的txt文件,那么代码如下:

运行脚本结果如下:

接下来导包,我们看看如何生成最简单的词云:

如果python引入无误,并代码无误,那么会弹出你生成的图片,该图片会储存在你的系统。详细位置一般为: C:\Users\MACHENIKE\AppData\Local\Temp 中。

带形状的词云

一般来说,我们不想要这么方的词云,肯定喜欢一些有形状的,

接下来是生成那种有轮廓的词云,这里就需要继续导入其他包,这里导入的包为numpy,numpy系统是python的一种开源的数值计算扩展,这种工具可以用来存储和处理大型矩阵。这里在处理的时候将给出形状的图片表示为一个大型矩阵,再有颜色的地方来进行填词(导包 :import numpy as np)。导包之后需添加一个遮罩层,遮罩层就是用来限制生成图片的形状 。

网上随便找个图片放入到项目当中(这里我找的是一个:heartpulse:),然后开始code:

结果如下:

不支持中文的解决方案

我又从网上摘抄了一段文字,文字内容如下:

生活星期天早上和朋友一起聊天,朋友说了一个他们听过的故事:“一尊佛像前有一条铺着石板的路,人们每天都踏着这一阶一阶的石板去膜拜佛像。石阶看着人们踏着自己去膜拜佛像,心里很不舒服。石阶心里想,自己和佛本来就来自同一块石头,为什么自己要成为踏脚石,让人们踩着自去去膜拜它呢!它对佛抱怨说这样太不公平!佛像说:这没有什么不公平,你们成为台阶只需挨了四刀,而我是挨了千刀万剐才成了人们膜拜的佛像。

重新运行,发现雪崩了。

如果需要生成中文的词云,还需导入jieba分词的包。jieba分词的切分还是蛮准的。

C盘中有font字体,那么这些呢你可以自己去找,trans_CN方法是分词用的,通过font-path就可以指定里面的生成文本。这大概就是词云的基础了,可以将爬虫和词云生成结合在一起,在爬取信息之后生成这样的词云。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 好的,下面是使用Python绘制词云图的步骤: 1. 安装相应的库:需要安装 wordcloud 和 matplotlib 这两个库。可以使用 pip install 命令进行安装。 2. 准备文本数据:需要准备一段文本数据,可以是从文件读取或者是从数据库获取。 3. 清洗文本数据:使用正则表达式或者其他方式对文本进行清洗,去除无用的字符或者词语。 4. 分词:使用 jieba 等分词库对文本进行分词。 5. 统计词频:统计每个词语在文本出现的次数。 6. 生成词云图:使用 wordcloud 库生成词云图,并使用 matplotlib 库进行可视化。 下面是一个简单的示例代码: ```python import jieba from wordcloud import WordCloud import matplotlib.pyplot as plt # 读取文本数据 with open('data.txt', 'r', encoding='utf-8') as f: text = f.read() # 分词 words = jieba.cut(text) # 统计词频 word_freq = {} for word in words: if word not in word_freq: word_freq[word] = 0 word_freq[word] += 1 # 生成词云图 wordcloud = WordCloud(background_color='white').generate_from_frequencies(word_freq) # 可视化 plt.imshow(wordcloud, interpolation='bilinear') plt.axis('off') plt.show() ``` 这个示例代码使用 jieba 库对文本进行分词,并使用 WordCloud 库生成词云图。最后使用 matplotlib 库进行可视化。 ### 回答2: Python可以使用多种库来绘制词云图,其比较常用的是wordcloud库。 首先,需要安装wordcloud库。可以使用pip命令来进行安装,打开命令提示符窗口并输入以下命令: ``` pip install wordcloud ``` 安装完成后,可以导入相应的库并使用其的函数来绘制词云图。一般情况下,绘制词云图的步骤如下: 1. 导入所需的库: ```python import wordcloud import matplotlib.pyplot as plt ``` 2. 配置词云图的参数: ```python # 配置词云图参数 wordcloud_obj = wordcloud.WordCloud(width=800, height=400, background_color='white') ``` 这里设置了词云图的宽度、高度和背景颜色等参数。 3. 生成词云图: ```python # 生成词云图 wordcloud_obj.generate(text) ``` 其`text`是用于生成词云图的文本数据。 4. 绘制词云图: ```python # 绘制词云图 plt.imshow(wordcloud_obj, interpolation='bilinear') plt.axis('off') # 隐藏坐标轴 plt.show() ``` 这里使用`imshow`函数来显示词云图,`axis('off')`可以隐藏坐标轴。 以上就是使用Python绘制词云图的基本步骤。根据具体需求,还可以对词云图进行更多的样式调整和处理,比如设置字体、颜色、形状以及词频的处理等。 ### 回答3: Python绘制词云图需要使用第三方库`wordcloud`,下面是绘制词云图的步骤。 首先,我们需要安装`wordcloud`库。在命令行使用以下命令安装: ``` pip install wordcloud ``` 安装完成后,我们可以开始绘制词云图。首先,导入`wordcloud`模块和`matplotlib`模块: ```python import matplotlib.pyplot as plt from wordcloud import WordCloud ``` 然后,我们需要准备文本数据,可以是一段文字、一篇文章、一本书等。假设我们的文本数据保存在一个字符串变量`text`。 接下来,我们可以创建一个`WordCloud`对象,并设置相应的参数。例如,可以设置词云图的宽度和高度、背景颜色、字体、最大词频等。以下是设置一些常用参数的示例代码: ```python wc = WordCloud(width=800, height=400, background_color='white', max_words=50, font_path='msyh.ttc') ``` 然后,将文本数据传递给`WordCloud`对象的`generate`方法,生成词云图的数据。例如: ```python wc.generate(text) ``` 接着,可以使用`matplotlib`库绘制词云图。创建一个新的图形并显示词云图: ```python plt.figure(figsize=(10, 5)) plt.imshow(wc, interpolation='bilinear') plt.axis('off') plt.show() ``` 最后,运行代码,即可绘制词云图。 需要注意的是,绘制词云图还可以通过设置`mask`参数来指定词云图的形状。`mask`可以是一个图片文件,也可以是一个二维数组。例如,可以使用如下代码设置一个心形的词云图: ```python from PIL import Image # 读取心形图片 heart_mask = np.array(Image.open("heart.png")) # 创建词云对象,并设置形状为心形 wc = WordCloud(mask=heart_mask, background_color='white', font_path='msyh.ttc') # 绘制词云图 plt.figure(figsize=(10, 10)) plt.imshow(wc, interpolation='bilinear') plt.axis('off') plt.show() ``` 以上是使用Python绘制词云图的简要步骤。不同的应用场景可能会有不同的参数设置和数据预处理方式,可以根据实际需要进行相应的调整。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值