• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    提取视频中的音频 Python只需要三行代码!

    身处数据爆炸增长的信息时代,各种各样的数据都飞速增长,视频数据也不例外。我们可以使用 python 来提取视频中的音频,而这仅仅需要安装一个体量很小的 python 库,然后执行三行代码!

    语音数据在数据分析领域极为重要。比如可以分析语义、口音、根据人的情绪等等。可以应用于偏好分析、谎话检测等等。

    一、提取音频

    需要用到 python 的 moviepy 库

    moviepy的 github 地址:https://github.com/Zulko/moviepy

    命令行 pip 安装上 moviepy 即可!

    pip install moviepy -i http://pypi.douban.com/simple --trusted-host pypi.douban.com
    

    提取音频:假设有一个 mp4 文件路径为"D:\python\pycharm2020\my_program\video_process\test_01.mp4",我们想提取其中的音频保存到"D:\python\pycharm2020\my_program\video_process\vst01.mp3",三行 Python 代码实现如下:

    import moviepy.editor as mpy
    
    
    # 截取背景音乐
    audio_background = mpy.AudioFileClip(r'D:\python\pycharm2020\my_program\video_process\test_01.mp4').subclip(1, 60)
    audio_background.write_audiofile(r'D:\python\pycharm2020\my_program\video_process\vst01.mp3')
    

    结果如下:

    执行上面的三行代码,就会发现音频文件已经成功提取到指定文件夹啦~ ~这里的视频格式和音频格式都支持其他格式,比如读取 mp4 格式视频,抽取其中的背景音乐保存为 MP3 格式音频。

    二、引力波绘制

    数据来源:

    从配置文档中读取时间相关数据

    import numpy as np  # 科学计算所用的numpy库
    import matplotlib.pyplot as plt  # 绘图所用的库matplotlib
    from scipy.io import wavfile  # 读取波形文件所用的库
    
    
    rate_h, hstrain = wavfile.read(r"H1_Strain.wav", "rb")   # 读取音频文件
    rate_l, lstrain = wavfile.read(r"L1_Strain.wav", "rb")
    # reftime, ref_H1 = np.genfromtxt('GW150914_4_NR_waveform_template.txt').transpose()
    reftime, ref_H1 = np.genfromtxt('wf_template.txt').transpose()  # 使用python123.io下载txt文件
    

    构造应变数据

    htime_interval = 1 / rate_h
    ltime_interval = 1 / rate_l
    fig = plt.figure(figsize=(12, 6))  # 创建大小为12*6的绘图空间
    
    # 丢失信号起始点
    htime_len = hstrain.shape[0] / rate_h  # 读取数据第一维的长度,得到函数在坐标轴上总长度
    htime = np.arange(-htime_len / 2, htime_len / 2, htime_interval)  # (起点,终点,时间间隔)
    

    使用来自 “H1” 探测器的数据作图

    plth = fig.add_subplot(221)  # 设置绘图区域
    plth.plot(htime, hstrain, 'r')  # 画出以时间为x轴,应变数据为y轴的图像,‘y'为黄色
    plth.set_xlabel('Time (seconds)')
    plth.set_ylabel('H1 Strain')
    plth.set_title('H1 Strain')
    

    绘制 L1 Strain 和Template

    ltime_len = lstrain.shape[0] / rate_l
    ltime = np.arange(-ltime_len / 2, ltime_len / 2, ltime_interval)
    pltl = fig.add_subplot(222)
    pltl.plot(ltime, lstrain, 'k')
    pltl.set_xlabel('Time (seconds)')
    pltl.set_ylabel('L1 Strain')
    pltl.set_title('L1 Strain')
    
    pltref = fig.add_subplot(212)
    pltref.plot(reftime, ref_H1, 'purple')
    pltref.set_xlabel('Time (seconds)')
    pltref.set_ylabel('Template Strain')
    pltref.set_title('Template')
    fig.tight_layout()  # 自动调整图像外部边缘
    

    保存并显示图像

    plt.savefig("Gravitational_Waves_Original.png")  # 保存图像为png格式
    plt.show()
    plt.close(fig)
    

    结果如下:

    以上就是提取视频中的音频 Python只需要三行代码!的详细内容,更多关于python 提取视频中的音频的资料请关注脚本之家其它相关文章!

    您可能感兴趣的文章:
    • Python从视频中提取音频的操作
    • Python做图像处理及视频音频文件分离和合成功能
    • ffmpeg+Python实现B站MP4格式音频与视频的合并示例代码
    • Python中操作各种多媒体,视频、音频到图片的代码详解
    • 利用Python小工具实现3秒钟将视频转换为音频
    • Python一键查找iOS项目中未使用的图片、音频、视频资源
    • python基于http下载视频或音频
    上一篇:Python-typing: 类型标注与支持 Any类型详解
    下一篇:python设置 matplotlib 正确显示中文的四种方式
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    提取视频中的音频 Python只需要三行代码! 提取,视频,中的,音频,Python,