Python基于wordcloud及jieba实现中国地图词云图
热词图很酷炫,也非常适合热点事件,抓住重点,以图文结合的方式表现出来,很有冲击力。下面这段代码是制作热词图的,用到了以下技术:
jieba,把文本分词
wordcloud,制作热图
chardet,辨别文件的编码格式,其中中文统一为GB18030,更加的兼容
imageio,提取图片的形状
其他:自动识别文件编码,自动识别txt文件,图片文件名与txt文件一致,使用的是四大名著的文本(自行百度),部分中国地图
上代码:
import osimport jiebaimport wordcloudimport chardetimport 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]))
输出:
水浒传的如下
西游记的如下
仔细看输出的内容,还是挺有意思的,哈哈哈。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持好吧啦网。
相关文章:
1. 解决Android Studio 格式化 Format代码快捷键问题2. JavaEE SpringMyBatis是什么? 它和Hibernate的区别及如何配置MyBatis3. SpringBoot+TestNG单元测试的实现4. Python使用urlretrieve实现直接远程下载图片的示例代码5. 完美解决vue 中多个echarts图表自适应的问题6. vue实现web在线聊天功能7. Springboot 全局日期格式化处理的实现8. 在Chrome DevTools中调试JavaScript的实现9. php解决注册并发问题并提高QPS10. Java使用Tesseract-Ocr识别数字
