失眠网,内容丰富有趣,生活中的好帮手!
失眠网 > python程序创建词云 中国地图_Python基于wordcloud及jieba实现中国地图词云图

python程序创建词云 中国地图_Python基于wordcloud及jieba实现中国地图词云图

时间:2019-03-05 14:47:34

相关推荐

python程序创建词云 中国地图_Python基于wordcloud及jieba实现中国地图词云图

热词图很酷炫,也非常适合热点事件,抓住重点,以图文结合的方式表现出来,很有冲击力。下面这段代码是制作热词图的,用到了以下技术:

jieba,把文本分词

wordcloud,制作热图

chardet,辨别文件的编码格式,其中中文统一为GB18030,更加的兼容

imageio,提取图片的形状

其他:自动识别文件编码,自动识别txt文件,图片文件名与txt文件一致,使用的是四大名著的文本(自行百度),部分中国地图

上代码:

import os

import jieba

import wordcloud

import chardet

import imageio

directory = "D:\\"

mask = imageio.imread(r"D:\map.jpg") # 用于最后图像图形

directory_lists = os.scandir(directory)

for directory_list in directory_lists:

if directory_list.is_dir() or directory_list.path.split('.')[-1] != "txt":

continue

with open(directory_list.path, 'rb') as fd:

coding = chardet.detect(fd.read()[:1000])['encoding']

if coding.upper() == 'GB2312' or coding == 'GBK':

coding = 'GB18030'

file = open(directory_list.path, 'r', encoding=coding)

text = file.read()

file.close()

jieba_text = ' '.join(jieba.lcut(text))

w = wordcloud.WordCloud(height=800, width=1600, font_path='msyh.ttc', background_color='white', stopwords={'Page'}, mask=mask)

w.generate(jieba_text)

w.to_file('{}.png'.format(directory_list.path.split('.')[0]))

输出:

水浒传的如下

西游记的如下

仔细看输出的内容,还是挺有意思的,哈哈哈。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持龙方网络。

如果觉得《python程序创建词云 中国地图_Python基于wordcloud及jieba实现中国地图词云图》对你有帮助,请点赞、收藏,并留下你的观点哦!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。