去除停用词并绘制词云图

简单处理数据后绘制词云图

以前看见词云图完全没想过它是怎么做出来的,现在才知道Python是可以画词云图的,而且非常简单,只要数据处理好。

# -*- coding: gb2312 -*-
#coding=gbk
import pandas as pd
import numpy as np
import jieba
from tkinter import _flatten
import matplotlib.pyplot as plt
from wordcloud import WordCloud
pd.set_option('display.max_columns',1000)
pd.set_option('display.width', 1000)
pd.set_option
  • 3
    点赞
  • 25
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
要对Excel文档中的多行文本进行分词后,去除停用词,并绘制词云图,需要使用Python中的一些第三方库和工具。以下是一个简单的实现步骤: 1. 安装必要的库和工具:需要安装Python的第三方库pandas、jieba、wordcloud和stopwords_cn。 2. 读取Excel文档中的多行文本:使用pandas库中的read_excel()函数读取Excel文档中的多行文本。 3. 对多行文本进行分词:使用jieba库对多行文本进行分词,并将分词结果存储到一个列表中。 4. 去除停用词:使用stopwords_cn库去除停用词,并将结果存储到一个列表中。 5. 统计词频:使用Python中的collections库中的Counter类对分词结果进行词频统计,并将结果存储到一个字典中。 6. 绘制词云图:使用wordcloud库中的WordCloud类绘制词云图,并设置字体、背景颜色、图片形状等参数。 以下是一个示例代码: ```python import pandas as pd import jieba from collections import Counter from wordcloud import WordCloud import matplotlib.pyplot as plt from stopwords_cn import stopwords # 读取Excel文档中的多行文本 data = pd.read_excel('data.xlsx') # 对多行文本进行分词 word_list = [] for line in data['text']: words = jieba.lcut(line) word_list += words # 去除停用词 new_word_list = [] for word in word_list: if word not in stopwords: new_word_list.append(word) # 统计词频 word_count = Counter(new_word_list) # 绘制词云图 wordcloud = WordCloud(font_path='msyh.ttf', background_color='white', width=800, height=600) wordcloud.generate_from_frequencies(word_count) plt.imshow(wordcloud) plt.axis('off') plt.show() ``` 其中,data.xlsx是一个包含多行文本的Excel文档,text是Excel表格中的列名。在代码中,我们使用了微软雅黑字体(msyh.ttf),白色背景,设置了词云图的宽度和高度。运行代码后,将会得到一个去除停用词后的词云图

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值