1. 导入需要的包package

import matplotlib.pyplot as plt
from scipy.misc import imread
from wordcloud import WordCloud,STOPWORDS
import xlrd

2. 设置生成词云图的背景图片,最好是分辨率高且色彩边界分明的图片

def set_background(picpath):
back_coloring = imread(picpath)# 设置背景图片,png等图片格式
return back_coloring

3. 创建词云图:WordCloud

def create_word_cloud(txt_str, back_coloring):  #txt_str表示导入的是字符串格式数据,#back_color表示的是背景图片位置
print('---- 根据词频,开始生成词云! ----')
font = r'C:\Windows\Fonts\simsun.ttc' #加载显示字体
wc = WordCloud(
font_path=font,
collocations=False, # 去重,如果不加,词云图会显示相同的词
stopwords=STOPWORDS, #加载停用词,如果不自己指定,则会加载默认的停用词
max_words=100,
width=2000,
height=1200,
# background_color='white',
mask=back_coloring,
)
wordcloud = wc.generate(txt_str)
# 写词云图片
wordcloud.to_file(".\wordcloud_test.png")
# 显示词云文件
plt.imshow(wordcloud)
plt.axis("off")
plt.show()

4. 默认的停用词一般在:假如anaconda安装在D盘,则会在其目录:D:\Anaconda3\Lib\site-packages\wordcloud\stopwords,其中都是英文词,例如:

注意:也可以在jieba分词中,先利用自己的停用词,得到去除停用词之后的文本字符串来绘制词云图:https://www.cnblogs.com/qi-yuan-008/p/11689530.html

5. 此时,词云图无法显示数字,这是因为 wc.generate 操作中,有去除数字的语句:在wordcloud.py中,第560行左右,所以想要显示数字,需要先注释这一行

6. 假设想要显示的词,已经经过jieba分词,保存在txt文档中,则绘制词云图的方法是:

例如:txt中是每行是一个词

则,先读取txt文件,形成字符串格式文本,再绘制

if __name__ == '__main__':
picpath = r".\xxx.png" #背景图片路径
back_coloring = set_background(picpath) with open(r".\jieba_分词数据.txt", "r",encoding='utf-8') as f:
remove_stop_str = f.read() create_word_cloud(remove_stop_str, back_coloring)

7. 如果通过jieba分词的数据已经处理成了(词, 词频)并保存在excel中,例如这种两列格式的excel表,第一行是标签如(词, 词频):

则可以先读取词频再显示,python读取excel数据可以通过 xlrd.open_workbook 方法:

def read_from_xls(filepath,index_sheet):
#读取文件名,filepath是excel文件的路径,index_sheet是第几个sheet
#读取表格#
# 设置GBK编码
xlrd.Book.encoding = "gbk"
rb = xlrd.open_workbook(filepath)
print(rb) sheet = rb.sheet_by_index(index_sheet)
nrows = sheet.nrows
data_tmp = [] for i in range(nrows - 1):
tt=i+1 #excel的第一行是标签
tmp_char = [str(sheet.cell_value(tt,0))] #第一列是词
tmp_num = int(sheet.cell_value(tt,1)) #第二列是词频
data_tmp.extend(tmp_char*tmp_num)
return data_tmp

然后,读数据和生成词云图:

if __name__ == '__main__':
picpath = r".\xxx.png"
back_coloring = set_background(picpath) data_dic = read_from_xls(r'D:\Python_workspace\spyder_space\jieba分词表.xlsx',0)
data_dic_str = '\n'.join(data_dic) #转成字符串格式 create_word_cloud(data_dic_str, back_coloring)

8. 总结代码

# -*- coding: utf-8 -*-
"""
Created on Mon Aug 19 10:47:17 2019 @author: Administrator
"""
import matplotlib.pyplot as plt
from scipy.misc import imread
from wordcloud import WordCloud,STOPWORDS
import xlrd def set_background(picpath):
back_coloring = imread(picpath)# 设置背景图片
return back_coloring def create_word_cloud(txt_str, back_coloring):
print('---- 根据词频,开始生成词云! ----')
font = r'C:\Windows\Fonts\simsun.ttc'
wc = WordCloud(
font_path=font,
collocations=False, # 去重
stopwords=STOPWORDS,
max_words=100,
width=2000,
height=1200,
# background_color='white',
mask=back_coloring,
)
wordcloud = wc.generate(txt_str)
# 写词云图片
wordcloud.to_file(".\wordcloud_test.png")
# 显示词云文件
plt.imshow(wordcloud)
plt.axis("off")
plt.show() def read_from_xls(filepath,index_sheet):
#读取文件名
#读取表格#
# 设置GBK编码
xlrd.Book.encoding = "gbk"
rb = xlrd.open_workbook(filepath)
print(rb) sheet = rb.sheet_by_index(index_sheet)
nrows = sheet.nrows
data_tmp = [] for i in range(nrows - 1):
tt=i+1
tmp_char = [str(sheet.cell_value(tt,0))]
tmp_num = int(sheet.cell_value(tt,1))
data_tmp.extend(tmp_char*tmp_num)
return data_tmp if __name__ == '__main__':
picpath = r".\xxx.png"
back_coloring = set_background(picpath)
data_dic = read_from_xls(r'D:\Python_workspace\spyder_space\jieba分词表.xlsx',0)
data_dic_str = '\n'.join(data_dic) # with open(r".\jieba_分词数据.txt", "r",encoding='utf-8') as f:
#    remove_stop_str = f.read()   create_word_cloud(data_dic_str, back_coloring)

# 当然绘制词云图的方法有很多,这只是其中的一种

python词云图之WordCloud的更多相关文章

  1. 特朗普退出《巴黎协定》:python词云图舆情分析

    1 前言 2017年6月1日,美国特朗普总统正式宣布美国退出<巴黎协定>.宣布退出<巴黎协定>后,特朗普似乎成了“全球公敌”. 特斯拉总裁马斯克宣布退出总统顾问团队 迪士尼董事 ...

  2. python词云生成-wordcloud库

    python词云生成-wordcloud库 全文转载于'https://www.cnblogs.com/nickchen121/p/11208274.html#autoid-0-0-0' 一.word ...

  3. python词云图与中文分词

    2019-12-12中文文本分词和词云图具体功能介绍与学习代码: import jiebaa="由于中文文本的单词不是通过空格或者标点符号来进行分割"#jieba.lcut()s是 ...

  4. 3.python词云图的生成

    安装库 pip install jieba wordcloud matplotlib 准备 txt文本 字体(simhei.ttf) 词云背景图片 代码 import matplotlib.pyplo ...

  5. (数据科学学习手札71)在Python中制作个性化词云图

    本文对应脚本及数据已上传至我的Github仓库https://github.com/CNFeffery/DataScienceStudyNotes 一.简介 词云图是文本挖掘中用来表征词频的数据可视化 ...

  6. 用Python制作酷炫词云图,原来这么简单!

    一.简介词云图是文本挖掘中用来表征词频的数据可视化图像,通过它可以很直观地展现文本数据中地高频词:! 图1 词云图示例 在Python中有很多可视化框架可以用来制作词云图,如pyecharts,但这些 ...

  7. python-2:爬取某个网页(虎扑)帖子的标题做词云图

    关键词:requests,BeautifulSoup,jieba,wordcloud 整体思路:通过requests请求获得html,然后BeautifulSoup解析html获得一些关键数据,之后通 ...

  8. 词云wordcloud类介绍&python制作词云图&词云图乱码问题等小坑

    词云图,大家一定见过,大数据时代大家经常见,我们今天就来用python的第三方库wordcloud,来制作一个大数据词云图,同时会降到这个过程中遇到的各种坑, 举个例子,下面是我从自己的微信上抓的微信 ...

  9. python 爬取豆瓣电影短评并wordcloud生成词云图

    最近学到数据可视化到了词云图,正好学到爬虫,各种爬网站 [实验名称] 爬取豆瓣电影<千与千寻>的评论并生成词云 1. 利用爬虫获得电影评论的文本数据 2. 处理文本数据生成词云图 第一步, ...

随机推荐

  1. Swift4.0复习整数,浮点数,布尔值

    1.类型相互转换: Int(a) Float(b) let a = Bool(truncating: NSNumber(value: c)) 2.元组: let tuple: (Int, String ...

  2. docker pull 提示错误的username or password

    安装完docker后,使用cli docker pull images 时,提示用户名密码错误 解决方法 使用docker ID 不要使用 Email 登陆. https://github.com/d ...

  3. 模型-视图-控制器的C++解释

    模型-视图-控制器 (MVC) 并非一种技术,而是软件设计/工程的一个概念.MVC包含三个组成部分,如下图所示 模型 模型直接响应对数据的处理,比如数据库.模型不应依赖其它组成部分,即视图或控制器,换 ...

  4. linux 下安装docker

    Linux 下的 Docker 安装与使用 一.安装与配置 安装一些必要的系统工具: sudo yum install -y yum-utils device-mapper-persistent-da ...

  5. KEGG富集分析散点图.md

    输入数据格式 pathway = read.table("kegg.result",header=T,sep="\t") pp = ggplot(pathway ...

  6. 记一次EFCore类型转换错误及解决方案

    一  背景 今天在使用EntityFrameworkCore 查询的时候在调试的时候总是提示如下错误:Unable to cast object of type 'System.Data.SqlTyp ...

  7. 1.http 协议和 https 协议的原理

    首先,我们得知道应用层是 OSI 七层网络模型的第七层,不同类型的网络应用有不同的通信规则,因此应用层协议是多种多样的,比如 DNS.FTP.Telnet.SMTP.HTTP. 等协议都是用于解决其各 ...

  8. Git--远程仓库版本回退方法

    Git--远程仓库版本回退方法 1 简介 最近在使用git时遇到了远程分支需要版本回滚的情况,于是做了一下研究,写下这篇博客. 2 问题 如果提交了一个错误的版本,怎么回退版本? 如果提交了一个错误的 ...

  9. vue利用keep-alive/beforeRouteLeave前进刷新后退不刷新(缓存)

      keep-alive缓存 在vue中默认router-link进入页面组件都是不缓存的.对于数据不会更新的页面.可以使用keep-alive来缓存以提高性能. 在项目src/router/inde ...

  10. PAT(B) 1051 复数乘法(Java)

    题目链接:1051 复数乘法 (15 point(s)) 参考博客:1051 复数乘法(PAT 乙级 C++实现)-guangjinzheng 题目描述 复数可以写成 (A+Bi) 的常规形式,其中 ...