matplotlib-bilibili,抖音很火的动态数据视频自动生成(第四节)-视频,语音合成

matplotlib-bilibili,抖音很火的动态数据视频自动生成(第四节)-视频,语音合成

大家好,又见面了,我是全栈君。

 matplotlib-bilibili,抖音很火的动态数据视频自动生成(第四节)-视频,语音自动合成

matplotlib-bilibili,抖音很火的动态数据视频自动生成(第四节)-视频,语音合成

还记得上一节中我们所提到的数据动态视频吗​?这次,为了让大家更加方便的制作自动生成视频,我们可在excel中自由配置数据,方便大家操作​,并且还增加了视频和语音自动合成的方式​。

 

01— 优化操作

 

第一步​:导入xlrd模块,并定义excel模板

matplotlib-bilibili,抖音很火的动态数据视频自动生成(第四节)-视频,语音合成

如上就是我们需要的模板​。

接下来我们来处理数据。

matplotlib-bilibili,抖音很火的动态数据视频自动生成(第四节)-视频,语音合成

 

第二步​:处理excel,返回相同时间的数据​。

import operator
import xlrd
​
f=xlrd.open_workbook("数据.xls")# 打开excel文件读取数据
sheet=f.sheet_by_index(0)
​
def sort_sheet(hour,name='数量'):
    list=[]
    ncols=sheet.ncols
    for i in range(1,sheet.nrows):
        if str(int(sheet.row_values(i)[1]))==str(hour):
            dict = {}
            for j in range(ncols):
                dict[sheet.cell_value(0,j)]=sheet.row_values(i)[j]
            list.append(dict)
    return sorted(list,key=operator.itemgetter(name))#升序排列
    # return sorted(list, key=operator.itemgetter(name),reverse=True)  # 降序排列

第三步​:定义颜色

color={"x":"#adb0ff","y":"#ffb3ff","z":"#90d595","a":"#FDF5E6"}

第四步​:建立图表

from matplotlib import animation
from matplotlib import pyplot
from pylab import mpl
​
mpl.rcParams['font.sans-serif'] =["SimHei"]
mpl.rcParams['axes.unicode_minus'] = False
fig, ax = pyplot.subplots()#返回一个包含figure和axes对象的元组,将元组分解为fig和ax两个变量
​
def  graph(num):
    ax.clear()#清除,不叠加
    list=sort_sheet(num)#调用上面定义的函数
    for i,chart_barh in enumerate(list):
        ax.barh(i,chart_barh["数量"],color=color[chart_barh["颜色"]])# 绘制水平方向的条形图barh()
        ax.text(chart_barh["数量"],i,chart_barh["名称"],size=14,weight=600,ha='left',va='bottom')#添加文字并设置样式
    ax.text(350, 2, num, size=20, weight=600, ha='left', va='bottom')
    ax.xaxis.set_ticks_position('top')
    ax.set_axisbelow(True)
    pyplot.xlim(0,300)
    pyplot.title('不同用户的文章点赞情况')#添加图标题
​
animator=animation.FuncAnimation(fig, graph, frames=range(1,24))
pyplot.show()#移动到函数外面,不然不会动态显示

制作结果​:如图

matplotlib-bilibili,抖音很火的动态数据视频自动生成(第四节)-视频,语音合成

第五步​:视频,音频合成,这里需要引入​os模块。

cmd = "ffmpeg -i %s -i %s %s" % (self.mp3, self.mp4, self.new_mp4)os.system(cmd)

注意:需要安装ffmpeg程序

windows如何安装ffmpeg

02— 完整代码

import os
from matplotlib import animation
from matplotlib import pyplot
from pylab import mpl
import operator
import xlrd
​
class chart(object):
    def __init__(self):
        f = xlrd.open_workbook("数据.xls")  # 打开excel文件读取数据
        self.sheet = f.sheet_by_index(0)
        self.color = {"x": "#adb0ff", "y": "#ffb3ff", "z": "#90d595", "a": "#FDF5E6"}
        mpl.rcParams['font.sans-serif'] = ["SimHei"]
        mpl.rcParams['axes.unicode_minus'] = False
        self.fig, self.ax = pyplot.subplots()  # 返回一个包含figure和axes对象的元组,将元组分解为fig和ax两个变量
        self.mp4 = 'E:\\数据动态展示.mp4'#生成视频名称,绝对路径
        self.mp3 = 'E:\\5018.mp3'#音频路径
        self.new_mp4 = 'E:\\new合成.mp4'#合成的mp4路径
    def sort_sheet(self,num,name='数量'):
        list=[]
        ncols=self.sheet.ncols
        for i in range(1,self.sheet.nrows):
            if str(int(self.sheet.row_values(i)[1]))==str(num):
                dict = {}
                for j in range(ncols):
                    dict[self.sheet.cell_value(0,j)]=self.sheet.row_values(i)[j]
                list.append(dict)
        return sorted(list,key=operator.itemgetter('数量'))#升序排列
        # return sorted(list, key=operator.itemgetter(name),reverse=True)  # 降序排列
    def  graph(self,num):
        self.ax.clear()#清除,不叠加
        list=self.sort_sheet(num)
        for i,chart_barh in enumerate(list):
            self.ax.barh(i,chart_barh["数量"],color=self.color[chart_barh["颜色"]])# 绘制水平方向的条形图barh()
            self.ax.text(chart_barh["数量"],i,chart_barh["名称"],size=14,weight=600,ha='left',va='bottom')#添加文字并设置样式
        self.ax.text(250, 2, str(num)+":00时", size=20, weight=600, ha='left', va='bottom')
        self.ax.text(200,0, "<---巍然不动", size=16, weight=600, ha='left', va='bottom')
        self.ax.xaxis.set_ticks_position('top')
        self.ax.set_axisbelow(True)
        pyplot.xlim(0,300)
        pyplot.title('不同用户的文章点赞情况')#添加图标题
    def mp4_and_mp3(self):
        animator = animation.FuncAnimation(self.fig, self.graph, frames=range(1, 24))
        animator.save(self.mp4)
        pyplot.show()
        cmd = "ffmpeg -i %s -i %s %s" % (self.mp3, self.mp4, self.new_mp4)
        os.system(cmd)
if __name__ == '__main__':
    chart=chart()
    chart.mp4_and_mp3()

matplotlib-bilibili,抖音很火的动态数据视频自动生成(第四节)-视频,语音合成

相关推荐(个人主页也有哦,赶快收藏起来)​:

动态数据视频(第一节)

bilibili,抖音很火的动态数据视频自动生成(第二节)

matplotlib-bilibili,抖音很火的动态数据视频自动生成(第三节)

matplotlib给女朋友画一个爱心吧,这份满满的爱意,一定要记得收下

欢迎关注我们

 

 

大家一起学编程

以学习为主,兴趣为辅,致力于开发,发现更多好玩有趣的编程技巧以及好玩有趣的编程思路。为喜欢编程和想要学习编程的人找到编程的乐趣和动力。

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/111362.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • RAID技术全解图解-RAID0、RAID1、RAID5、RAID100

    图文并茂RAID技术全解–RAID0、RAID1、RAID5、RAID100……  RAID技术相信大家都有接触过,尤其是服务器运维人员,RAID概念很多,有时候会概念混淆。这篇文章为网络转载,写得相当不错,它对RAID技术的概念特征、基本原理、关键技术、各种等级和发展现状进行了全面的阐述,并为用户如何进行应用选择提供了基本原则,对于初学者应该有很大的帮助。一、RAID概…

    2022年4月7日
    147
  • context.xml

    context.xmlWEB-INF/web.xml–>–>

    2022年7月3日
    18
  • Keil(MDK-ARM)系列教程(一)_新建软件工程详细过程

    Keil(MDK-ARM)系列教程(一)_新建软件工程详细过程推荐分享一个大神的人工智能教程。零基础!通俗易懂!风趣幽默!还带黄段子!希望你也加入到人工智能的队伍中来!http://www.captainbed.net/strongerhuang推荐在我的公众号「strongerHuang」或网站(www.strongerhuang.com)阅读以下教程:Keil系列教程01_Keil介绍、下载、安装与注册Keil系列教程02_新建基础…

    2022年5月24日
    41
  • vuejs — 父组件向子组件传值(父传子)「建议收藏」

    vuejs — 父组件向子组件传值(父传子)「建议收藏」来看一下vue中的父组件向子组件传值的过程:首先,举个例子:有子组件—-A.vueB.vueC.vueA.vue中有一个数组-》listArr,这个数组在B.vue和C.vue中也要用到,每个页面都去写listArr数组,比较麻烦那怎么用简单…

    2022年5月11日
    51
  • sqlyog安装教程注册码_vlive安卓安装包

    sqlyog安装教程注册码_vlive安卓安装包SQLyog是啥?一款很好用的mysql客户端工具 安装包与注册码链接:中文版SQLyog,64位32位都有密码:p6xk花了我3个C币…且用且珍惜(╥╯^╰╥)听说很好用,等我用熟练了出个使用教程…

    2022年9月23日
    3
  • OTSU算法(大津法阈值分割原理)

    写在前面大津法(OTSU)是一种确定图像二值化分割阈值的算法,由日本学者大津于1979年提出。从大津法的原理上来讲,该方法又称作最大类间方差法,因为按照大津法求得的阈值进行图像二值化分割后,前景与背景图像的类间方差最大。它被认为是图像分割中阈值选取的最佳算法,计算简单,不受图像亮度和对比度的影响,因此在数字图像处理上得到了广泛的应用。它是按图像的灰度特性,将图像分成背景和前景两部分。因方差…

    2022年4月18日
    186

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号