本文的文字及图片来源于网络,仅供学习、交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理。
作者:朱小五
PS:如有需要Python学习资料的小伙伴可以加点击下方链接自行获取
python免费学习资料点击即可领取
python学习交流群点击即可加入
相信大家也都通过各种渠道了解了老干妈与鹅厂的爱恨纠缠,当然其中还混入了迷惑行为的“骗子”、吃瓜吃得飞起的“阿里系”以及连称此事与我无关的“某搜索引擎”。
不过这是一篇技术文,所以无心管他到底是谁的老千妈,一心只想给大家介绍这个惊艳的好东西。
我事先分别用python爬取了腾讯和老干妈的回应微博下的评论(老干妈没有微博,换成了老干妈警方公告下的评论),jieba分词得到结果后,分别制作词云。左边是用经典的wordcloud,右侧则是今天的主角stylecloud。
对我而言,平时python制作词云主要使用wordcloud,如果在可视化的过程还要用Pyecharts做其他图,那么词云也干脆就用Pyecharts制作了。
有同学也觉得stylecloud颜值颇高,那今天就带大家捋一捋它的使用方法。
stylecloud 是一个 Python 包,一位数据科学家Max Woolf基于wordcloud优化改良而成。并添加了一些有用的功能,从而创建出独特的词云。
stylecloud 具备以下特点:
两行代码
stylecloud的对于处理英文词云有个酷炫的功能,可以实现两行代码实现词云,一行导入stylecloud,另外一行直接调用。
不过我们还是要先安装包 ↓
pip3 install stylecloud
以这里的Trump.txt为例,它是特朗普当选美国总统的演讲稿,直接生成词云。
from stylecloud import gen_stylecloud
gen_stylecloud(file_path='Trump.txt')
生成效果如下:
是不是非常快捷高效,不过对于中文文本我们还是需要先分词再做处理。
影响词云颜值的问题之一就是蒙版图片的生成。
自己制作的要么分辨率不统一,要么需要调整对比度,比较麻烦。stylecloud
是直接使用Font Awesome这个现成的方案,wordcloud
其实也可以用。
网址:https://fontawesome.com/license/free
在stylecloud \ static的文件夹中,有一个fontawesome.min.css文件包含了巨量的图标,你可以定期到官方网站去升级这个图标库。
打开发现里面包含很多图标的代码,具体长什么样呢?
多亏有中文网站分门别类罗列了图标的样子和名字,
比如:https://fontawesome.dashgame.com/
它最新版地址:https://fa5.dashgame.com/#/%E5%9B%BE%E6%A0%87
,图标介绍更详细,分类更全面,不过经常抽风。
使用方法如下:
如果我们想要使用小狗的蒙版,只需先查找到它的图标名字fa-dog
,再加入到参数中icon_name='fas fa-dog'
即可。
stylecloud.gen_stylecloud(text=' '.join(text1), collocations=False,
font_path=r'C:\Windows\Fonts\msyh.ttc',
icon_name='fas fa-dog',
size=400,output_name='词云.png')
然后我换了一堆小动物的蒙版,生成了如下的词云动图:
其实企鹅并没有在动物里找到,不过我想起来了QQ的图标就是,但是替换后是报错的。原来品牌的图标前缀与其他不同,需要改为icon_name='fab fa-qq'
,这样就可以啦。
配色是影响词云颜值的又一大问题。stylecloud同样找到了比较好的方案,配色方案是使用的高级调色板palettable来实现了。
palettable 网站:https://jiffyclub.github.io/palettable/
这是一款专业的配色网站,非常适合我们这种对词云的美观有一点小追求的人。
里面的配色方案超级多,随便点击几个给大家预览一下:
我们可以通过修改参数palette='配色方案'
来达到更改自己词云配色的目的。
stylecloud.gen_stylecloud(text=' '.join(text1), collocations=False,
palette='tableau.BlueRed_6',
font_path=r'C:\Windows\Fonts\msyh.ttc',
icon_name='fab fa-qq',size=400,
output_name='腾讯-词云.png')
其他参数
以下参数对 stylecloud Python 函数和 CLI 均有效,你可以通过 stylecloud -h 获取这些参数的信息。[3]
上面参数由机器之心翻译自stylecloud的github介绍,我就直接引用,不班门弄斧了。
更多详情可以打开链接:https://github.com/minimaxir/stylecloud
最后终于挑选好了自己喜欢的参数,成功生成“腾讯”微博下的评论词云:
import stylecloud
from IPython.display import Image
stylecloud.gen_stylecloud(text=' '.join(text1), collocations=False,
font_path=r'C:\Windows\Fonts\msyh.ttc',
icon_name='fab fa-qq',size=400,
output_name='腾讯-词云.png')
Image(filename='腾讯-词云.png')
对于颜值要求稍微高一点的同学,可以使用Adobe Photoshop、Adobe Illustrator继续美化图片呦!