• Python


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

    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]))

    输出:

    水浒传的如下

     西游记的如下

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

  • 相关阅读:
    PLSQL设置数据库选项
    Oracle 11g客户端下载地址
    js将html转换为纯文本
    创建 dblink
    网页禁用表单的自动完成功能禁用密码自动填充autocomplete
    解决oracle11g的ORA-12505问题
    Linux的XServer
    Qt移植对USB鼠标键盘、触摸屏的支持
    Qt5.2.1交叉编译,带tslib插件
    ubuntu 12.04 桌面版关闭图形界面
  • 原文地址:https://www.cnblogs.com/johnthegreat/p/12595892.html
Copyright © 2020-2023  润新知