手把手教你如何绘制自己的跳舞词云图~

简介: 首先我们要先准备一个热舞视频,从哪里下载的都可以,我是用You-Get从B站上下载的,命令如下:

01下载视频


首先我们要先准备一个热舞视频,从哪里下载的都可以,我是用You-Get从B站上下载的,命令如下:


you-get url


1.gif

you-get是第三方库,需要读者用pip进行手动安装,它的更多用法可以看看这篇文章下载全网音视频资源的神器—You-get


02分割视频


下载好视频后,我们要对其进行分割处理,将其变成一张一张的图片,代码如下:


import cv2
vc = cv2.VideoCapture(r'美女跳舞视频.flv')  # 读取视频文件
n = 1# 计数
a, b = vc.read()
timeF = 10# 视频帧计数间隔频率
num = 0
while a:  # 循环读取视频帧
   a, b = vc.read()
   if (n % timeF == 0):  # 每隔timeF帧进行存储操作
       num += 1
       cv2.imwrite(f'{num}.jpg',b)  # 存储为图像
   n += 1
   cv2.waitKey(1)
vc.release()


让我们来看看效果:


39.png


03人物抠像


视频现在已经分割成一张一张的图片了,我们要把人物给抠出来,这样方便我们进行词云图绘制。


这里我是借用的百度API进行人物抠像,下面我们来看一下如何使用百度API。


首先,我们先打开百度AI界面,然后点击控制台。


40.png


跳转到登陆界面后,输入账号密码后,跳转到管理界面,此时我们点击人体分析。进入到人体分析应用界面。


41.png


然后创建一个应用(如已创建好,就点击管理应用)。


42.png



创建好后,进入到应用列表中,记下来‘AppID’、‘API Key’、‘Secret Key’这三个参数的值。在后面对API进行调用的时候需要用到这三个参数。


43.png


接下来,我们就可以开始调用API了,代码如下:


""" 读取图片 """
def get_file_content(filePath):
  with open(filePath, 'rb') as fp:
  return fp.read()image = get_file_content('example.jpg')
""" 调用人像分割 """
client.bodySeg(image);
""" 如果有可选参数 """
options = {}
options["type"] = "labelmap"
""" 带参数调用人像分割 """
client.bodySeg(image, options)


我们来看一下效果:


44.gif


我们使用的代码如下:


APP_ID = '你的APP_ID'
API_KEY = '你的API_KEY'
SECRET_KEY = '你的SECRET_KEY'
client = AipBodyAnalysis(APP_ID, API_KEY, SECRET_KEY)
path = r'美女跳舞视频'
img_files = os.listdir(r'img')
print(img_files)
for num in range(2, len(img_files) + 1):
   img = f'img_{num}.jpg'
   img_1 = cv2.imread(img)
   height, width = img_1.shape[:2]
   with open(img, 'rb') as fp:
       img_info = fp.read()
   seg_res = client.bodySeg(img_info)
   labelmap = base64.b64decode(seg_res['labelmap'])
   nparr = np.frombuffer(labelmap, np.uint8)
   labelimg = cv2.imdecode(nparr, 1)
   labelimg = cv2.resize(labelimg, (width, height), interpolation = cv2.INTER_NEAREST)
   new_img = np.where(labelimg  == 1, 255, labelimg)
   mask_name = path + 'mask_{}.png'.format(num)
   cv2.imwrite(mask_name,new_img)


让我们来看看效果,感觉还不错:


45.png


04词云绘制


现在人物也出来了,我们可以开始进行词云的绘制了,这里我们使用的是上次从抖音视频上爬取下来的评论,读者也可以替换成自己的评论,代码如下:


for num in range(1,23):
   with open("comment.txt", 'r') as f:
       job_title_1 = f.read()
   contents_cut_job_title = jieba.cut(job_title_1)
   contents_list_job_title = " ".join(contents_cut_job_title)
   img = f'mask_{num}.png'
   mask = 255 - np.array(Image.open(img))  # 相互转化
   wc = WordCloud(stopwords=STOPWORDS.add("一个"), collocations=False,
                  background_color="white",
                  font_path=r"K:\msyh.ttc",
                  width=400, height=300, random_state=42,
                  mask=mask
                  )
   wc.generate(contents_list_job_title)
   wc.to_file(f"ciyun_{num}.png")


让我们来看看效果:


46.png


05合成视频


词云图做好了,我们现在要将他们合成一个视频,这样就可以实现其跳舞的特效啦,代码如下:


import cv2
video_address = 'tiaowu.mp4'# 输出视频的保存路径
fps = 20# 帧率,可以调整
img_size = (1080, 1920)  #  图片的大小
fourcc = cv2.VideoWriter_fourcc('M', 'P', '4', 'V')
videoWriter = cv2.VideoWriter(video_address , fourcc, fps, img_size)
for num in range(1,23):
   img_path = f'ciyun_{num}.png'
   frame = cv2.resize(cv2.imread(img_path), img_size)  
   videoWriter.write(frame)      # 合成视频
videoWriter.release()



06小结


1. 本文详细介绍了如何制作一款跳舞的词云图,有兴趣的读者可以尝试自己动手实验一下。

2. 本文绘制词云图的操作是最基本的,其实还可以更优,有兴趣的读者可以看看这篇文章基于微博评论的文本情感分析与关键词提取的实战案例~

3. 让词云图绘制在人像中,要让PIL.Image与numpy.array之间进行相互转换。

4. 本文仅供学习参考,不做它用。

相关文章
|
2月前
|
数据可视化 Python
Plotly:绘制蜡烛图
Plotly:绘制蜡烛图
44 0
教你一招学会Echarts绘制瀑布图
教你一招学会Echarts绘制瀑布图
|
5月前
|
搜索推荐 数据可视化 前端开发
ECharts 词云图案例【用户画像】:创意蒙版应用
使用ECharts创建词云图,结合蒙版技术提升可视化创意。通过设置`maskImage`属性,将自定义图像作为词云的外形,如用户画像。案例中详细介绍了HTML结构、ECharts配置及蒙版图像加载过程,鼓励探索SVG路径和CSS样式以实现更多个性化效果。代码和依赖可下载,激发更多数据可视化灵感。
246 0
 ECharts 词云图案例【用户画像】:创意蒙版应用
|
6月前
|
XML 自然语言处理 数据格式
py获取《灵笼》第一集的弹幕———绘制词云图
py获取《灵笼》第一集的弹幕———绘制词云图
34 0
|
6月前
手把手带你绘制条形图
手把手带你绘制条形图
87 0
Echarts实战案例代码(29):来找茬,柱状图在F11全屏下显示三角形的异形情况案例
Echarts实战案例代码(29):来找茬,柱状图在F11全屏下显示三角形的异形情况案例
117 0
|
移动开发 数据可视化 HTML5
R可视化学习—词云图
词云。又称文字云。“词云”就是通过形成“关键词云层”或“关键词渲染”,对网络文本中出现频率较高的“关键词”的视觉上的突出,它会过滤掉大量的文本信息,使浏览网页者只要一眼扫过文本就可以领略文本的主旨。
164 0
|
自然语言处理 数据可视化 测试技术
软件测试|教你使用Python快速绘制酷炫词云图
软件测试|教你使用Python快速绘制酷炫词云图
软件测试|教你使用Python快速绘制酷炫词云图
|
数据采集 数据可视化 数据挖掘
还在用饼状图?来瞧瞧这些炫酷的百分比可视化新图形(附代码实现)⛵
本文讲解9种『炫酷高级』的数据图表,可视化地表示比例或百分比:哑铃图、甜甜圈图、华夫饼图、堆积条形图...附上代码,快快用起来吧!
858 2
还在用饼状图?来瞧瞧这些炫酷的百分比可视化新图形(附代码实现)⛵
|
Python
Matplotlib从入门到精通:第一张图
Matplotlib从入门到精通:第一张图
147 0
Matplotlib从入门到精通:第一张图