python生成自定义形态词云,语义分割完美

简介: python生成自定义形态词云,语义分割完美

python生成词云


介绍


使用python生成自己需要的词云,词云形状可以根据图片自定义


完整地址点击跳转


软件架构



PyCharm 2021.2.3 (Professional Edition)

内部版本号 #PY-212.5457.59,October 19, 2021 构建

运行时版本: 11.0.12+7-b1504.40 x86_64

VM: OpenJDK 64-Bit Server VM,JetBrains s.r.o.

macOS 12.1


安装教程


下载压缩包,解压后整个导入编译器


使用说明


下载所需要的拓展库(依次输入下载语句)


pip install wordcloud

pip install jieba


# setting paths
fname_text = 'texts/article.txt'            #你需要生成词云的文件地址
fname_stop = 'hit_stopwords.txt'                #分词文件地址,不能动
fname_mask = 'owl.jpeg'             #生成词云所用的背景地址
fname_font = 'simhei.ttf'           #生成词云文字的字体地址,可更改自己需要的字体


完整代码


import numpy as np
from wordcloud import WordCloud, ImageColorGenerator  # , STOPWORDS
import matplotlib.pyplot as plt
from PIL import Image
import jieba  # cutting Chinese sentences into words
def plt_imshow(x, ax=None, show=True):
  if ax is None:
    fig, ax = plt.subplots()
  ax.imshow(x)
  ax.axis("off")
  if show: plt.show()
  return ax
def count_frequencies(word_list):
  freq = dict()
  for w in word_list:
    if w not in freq.keys():
      freq[w] = 1
    else:
      freq[w] += 1
  return freq
if __name__ == '__main__':
  # setting paths
  fname_text = '商务英语特征与翻译难点探讨.txt'
  fname_stop = 'hit_stopwords.txt'
  fname_mask = 'touxiang.JPG'
  fname_font = 'simhei.ttf'
  # read in texts (an article)
  text = open(fname_text, encoding='utf8').read()
  # Chinese stop words
  STOPWORDS_CH = open(fname_stop, encoding='utf8').read().split()
  # processing texts: cutting words, removing stop-words and single-charactors
  word_list = [
    w for w in jieba.cut(text)
    if w not in set(STOPWORDS_CH) and len(w) > 1
  ]
  freq = count_frequencies(word_list)
  # processing image
  im_mask = np.array(Image.open(fname_mask))
  im_colors = ImageColorGenerator(im_mask)
  # generate word cloud
  wcd = WordCloud(font_path=fname_font,  # font for Chinese charactors
                  background_color='white',
                  mode="RGBA",
                  mask=im_mask,
                  )
  # wcd.generate(text) # for English words
  wcd.generate_from_frequencies(freq)
  wcd.recolor(color_func=im_colors)
  # visualization
  ax = plt_imshow(wcd, )
  ax.figure.savefig(f'single_wcd.png', bbox_inches='tight', dpi=150)
  fig, axs = plt.subplots(1, 2)
  plt_imshow(im_mask, axs[0], show=False)
  plt_imshow(wcd, axs[1])
  fig.savefig(f'conbined_wcd.png', bbox_inches='tight', dpi=150)



参与贡献者


  1. Cynthxxx
  2. 灿烂
相关文章
|
2月前
|
Python
python简单分割文件的方法(python经典案例)
这篇文章介绍了两种使用Python进行文件分割的方法:通过读取指定字节数分割大文件成小文件,以及通过行数将文本文件分割成多个小文件。
56 1
|
3月前
|
Python
探索Python中的魔法方法:打造你自己的自定义对象
【8月更文挑战第29天】在Python的世界里,魔法方法如同神秘的咒语,它们赋予了对象超常的能力。本文将带你一探究竟,学习如何通过魔法方法来定制你的对象行为,让你的代码更具魔力。
42 5
|
12天前
|
自然语言处理 Python Windows
python知识点100篇系列(23)- 使用stylecloud生成词云
【10月更文挑战第10天】`stylecloud` 是 `wordcloud` 的优化版,支持使用 Font Awesome 图标自定义词云形状,操作更简便。本文介绍如何安装 `jieba` 和 `stylecloud` 库,并使用它们生成中文词云。通过 `jieba` 进行分词,再利用 `stylecloud` 的 `gen_stylecloud` 方法生成具有特定形状和颜色的词云图像。
python知识点100篇系列(23)- 使用stylecloud生成词云
|
1月前
|
自然语言处理 计算机视觉 Python
用 Python 创建词云
用 Python 创建词云
24 2
|
2月前
|
jenkins 持续交付 Docker
docker之自定义制作镜像(python程序)
docker之自定义制作镜像(python程序)
|
2月前
|
Linux UED iOS开发
Python中的自定义进度条:从零开始
Python中的自定义进度条:从零开始
|
21天前
|
Python
python知识点100篇系列(14)-分割大文件然后在合并
【10月更文挑战第2天】在工作中,因邮件附件大小限制或网络条件不佳,常需将大文件分割为小文件发送,接收后再合并。Python的文件读写功能可轻松实现此需求,也可借助第三方库filesplit简化操作。安装filesplit后,仅需几行代码即可完成文件的分割与合并,但掌握Python内置方法同样重要。
|
26天前
|
程序员 开发者 Python
深度解析Python中的元编程:从装饰器到自定义类创建工具
【10月更文挑战第5天】在现代软件开发中,元编程是一种高级技术,它允许程序员编写能够生成或修改其他程序的代码。这使得开发者可以更灵活地控制和扩展他们的应用逻辑。Python作为一种动态类型语言,提供了丰富的元编程特性,如装饰器、元类以及动态函数和类的创建等。本文将深入探讨这些特性,并通过具体的代码示例来展示如何有效地利用它们。
29 0
|
3月前
|
前端开发 Python
使用Python+openpyxl实现导出自定义样式的Excel文件
本文介绍了如何使用Python的openpyxl库导出具有自定义样式的Excel文件,包括设置字体、对齐方式、行列宽高、边框和填充等样式,并提供了完整的示例代码和运行效果截图。
109 1
使用Python+openpyxl实现导出自定义样式的Excel文件
|
2月前
|
Python
Python将目录分割成数组
Python将目录分割成数组