使用ffmpeg从视频文件中提取音频文件、视频抽帧和切割视频

这篇具有很好参考价值的文章主要介绍了使用ffmpeg从视频文件中提取音频文件、视频抽帧和切割视频。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

ffmpeg下载

使用ffmpeg从视频文件中提取音频文件

批量提取文件夹下多个视频文件的音频

使用ffmpeg从视频文件中提取视频帧

使用ffmpeg将按固定时长将视频切割成多个小片段

将分割得到的视频存放在新建文件夹下(这个我运行的时候好像有点问题,音频文件没有存放在新建的文件夹中)

批量处理多个视频

将输出文存储在文件夹中,命名与原视频一致


ffmpeg下载

先下载ffmpeg软件,可以参考下面这个链接,下载不了可以参考里面的评论区,我下载的时候参考过评论区的方法

Windows下下载安装ffmpeg - 知乎 (zhihu.com)

使用ffmpeg从视频文件中提取音频文件

MP3文件和WAV文件都是数字音频格式,由于两者的压缩比例和编码上面的差异,因此但是两者在文件大小和音质上有所不同。WAV是最接近无损的音乐格式,MP3文件通过对音频进行编码,去掉了某些部分,从而节省了空间。

使用 -f wav 输出wav格式音频文件:

E:\>ffmpeg -i test.mp4 -vn -f wav output.wav

使用 -f mp3 输出mp3格式音频文件:

E:\>ffmpeg -i test.mp4 -vn -f mp3 output.mp3

使用 -c:a mp3 输出mp3格式音频文件: 

E:\>ffmpeg -i test.mp4 -vn -c:a mp3 output.mp3

试了一下提取mp3文件比提取wav文件慢一些,也不清楚两种提取mp3文件的方法有什么区别

  •  -i   输入文件,test.mp4 为原始视频文件;
  •  -vn  表示no video,输出不包含视频
  •  -f   输出文件格式
  • output.mp3 /output.wav为处理结果文件;

批量提取文件夹下多个视频文件的音频

在该目录下创建一个批处理文件(例如 music.bat)

在批处理文件中添加以下命令:

for %%a in (*.mp4) do ffmpeg -i %%a -vn -f wav %%~na.wav

使用ffmpeg从视频文件中提取音频文件、视频抽帧和切割视频

使用ffmpeg从视频文件中提取音频文件、视频抽帧和切割视频

使用ffmpeg从视频文件中提取视频帧

ffmpeg -i output_000.mp4 -r 8 -f image2 ./%05d.jpg
ffmpeg -i output_000.mp4 -vf fps=fps=8 -f image2 ./%05d.jpg

上面两个指令都可以

其中 -r 8 -vf fps=fps=8 均表示按 fps = 8 进行抽帧 

得到的结果如下图所示,但是我是将10s的视频进行提取,按理说应该是10*8=80帧,但是最终刚得到的是86张图片,这个10s的视频是按照下面的方法将大视频按照固定时长(10s)切割成小片段得到的,不太清楚这是怎么回事。

使用ffmpeg从视频文件中提取音频文件、视频抽帧和切割视频

使用ffmpeg将按固定时长将视频切割成多个小片段

ffmpeg -i input_video.mp4 -c copy -map 0 -segment_time 60 -f segment output_%03d.mp4

这个命令将会把 "input_video.mp4" 这个视频按照60秒的时长切割成多个小片段,每个小片段保存在以 "output_001.mp4", "output_002.mp4", "output_003.mp4" ...等格式命名的文件中。

命令的解释:

  • -i input_video.mp4: 输入视频文件的路径和文件名。
  • -c copy: 使用“copy”编解码器,将视频从输入直接复制到输出,不做任何修改。
  • -map 0: 将输入文件中的所有流全部复制到输出文件中。
  • -segment_time 60: 视频分段的时间长度,这里设置为60秒。
  • -f segment: 指定输出格式为分段的视频格式。
  • output_%03d.mp4: 输出文件的名称格式,%03d 表示输出文件名以 3 位数字为格式,例如 output_001.mp4。

这个命令将会在同级目录下生成一系列的小片段视频文件,可以根据需要自定义参数来满足需求。

请注意,上述示例中的命令行参数 -c copy 表示使用“copy”编解码器,将视频从输入直接复制到输出,不做任何修改。如果你需要对视频进行转码或其他处理,请根据需要修改命令行参数。

将分割得到的视频存放在新建文件夹下(这个我运行的时候好像有点问题,音频文件没有存放在新建的文件夹中)

import os
import subprocess

input_video = "input_video.mp4"
output_folder = os.path.splitext(input_video)[0]  # 获取文件名去掉扩展名的部分作为输出文件夹名
os.makedirs(output_folder, exist_ok=True)  # 创建输出文件夹,如果已经存在则不会报错

command = ["ffmpeg", "-i", input_video, "-c", "copy", "-map", "0", "-segment_time", "60", "-f", "segment", os.path.join(output_folder, f"{input_video}_%03d.mp4"), "-reset_timestamps", "1", "-strftime", "1", "-v", "warning", "-stats", "-hide_banner", "-nostdin", "-y", "-vcodec", "copy", "-acodec", "copy", "-copyts", "-avoid_negative_ts", "make_zero"]
subprocess.run(command)

批量处理多个视频

首先,将 ffmpeg.exe 和所有需要处理的视频文件放在同一个目录下。

然后,在该目录下创建一个批处理文件(例如 batch_process.bat)。

在批处理文件中添加以下命令:

for %%a in (*.mp4) do ffmpeg -i "%%a" -c copy -map 0 -segment_time 60 -f segment "output_%%~na_%%03d.mp4"

这个命令将对该目录下的所有 mp4 文件进行处理。假设我们有一个名为 "video1.mp4" 的视频文件,该命令将生成以下文件:

  • output_video1_001.mp4
  • output_video1_002.mp4
  • output_video1_003.mp4
  • ...

其中 "video1" 是输入文件的名称。

保存并运行该批处理文件,它将会自动对目录下的所有 mp4 文件进行处理,生成相应的分段视频文件。

注意:如果视频文件不是以 mp4 格式结尾,可以将 *.mp4 替换为相应的格式。同时,如果需要修改分段视频文件的命名格式,可以根据自己的需求修改输出文件名的格式。

将输出文存储在文件夹中,命名与原视频一致

import glob
import os
import subprocess


def split_video(input_file, duration):
    output_folder = os.path.splitext(input_file)[0]
    if not os.path.exists(output_folder):
        os.makedirs(output_folder)

    command = ['ffmpeg', '-i', input_file, '-c', 'copy', '-f', 'segment', '-reset_timestamps', '1', '-segment_time',
               str(duration), '-map', '0', os.path.join(output_folder, 'output_%03d.mp4')]
    subprocess.call(command)


if __name__ == '__main__':
    duration = 10 # 单位是秒,这里设置每个片段的时长为10秒
    input_folder = r"E:\video"
    for input_video in glob.glob(os.path.join(input_folder, "*.mp4")):
        split_video(input_video, duration)

下面是代码运行的效果 

使用ffmpeg从视频文件中提取音频文件、视频抽帧和切割视频

使用ffmpeg从视频文件中提取音频文件、视频抽帧和切割视频文章来源地址https://www.toymoban.com/news/detail-401705.html

到了这里,关于使用ffmpeg从视频文件中提取音频文件、视频抽帧和切割视频的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 使用FFMPEG分离mp4/flv文件中的264视频和aac音频

    ffmpeg 4.4 一个MP4或flv格式的视频文件 大致分为以下几个简单步骤: 1.使用avformat_open_input 函数打开文件并初始化结构AVFormatContext 2.查找是否存在音频和视频信息 3.构建一个h264_mp4toannexb比特流的过滤器,用来给视频avpaket包添加头信息 4.打开2个输出文件(音频, 视频) 5.循环读

    2024年02月15日
    浏览(26)
  • 使用FFMPEG库封装264视频和acc音频数据到MP4文件中

    ffmepeg 4.4 一段H264的视频文件 一段acc格式的音频文件 1.使用avformat_open_input分别打开视频和音频文件,初始化其AVFormatContext,使用avformat_find_stream_info获取编码器基本信息 2.使用avformat_alloc_output_context2初始化输出的AVFormatContext结构 3.使用函数avformat_new_stream给输出的AVFormatContext结

    2024年02月11日
    浏览(32)
  • 基于Whisper语音识别的实时视频字幕生成 (一): 流式显示视频帧和音频帧

    Whistream(微流)是基于Whisper语音识别的的在线字幕生成工具,支持rtsp/rtmp/mp4等视频流在线语音识别 whishow(微秀)是python实现的在线音视频流播放器,支持rtsp/rtmp/mp4等流式输入,也是whistream的前端。python实现原理如下: (1) SPROCESS.run() 的三个子线程负责:缓存流数据,处理音

    2024年04月13日
    浏览(39)
  • 提取视频文件里的音频和无声视频

    一、提取视频文件里的音频: 二、提取视频文件里的无声视频

    2024年02月11日
    浏览(27)
  • 怎么视频提取音频文件?分享这3种简单实用的提取方法

    不知道大家平时用手机刷视频的时候,会不会被一些好听的背景音乐给吸引了呢?这些背景音乐大多都是网友们自己合成导入视频上传的,可能在许多音乐平台都不能找到音源播放。遇到这样的情况,大家一定都很苦恼吧?但其实,我们可以使用一些软件将视频中的音频提取

    2023年04月09日
    浏览(29)
  • ffmpeg 截取切割视频报错

    在用ffmpeg来截取只有视频没有音频的mp4文件时,有一些视频可以切割,少部分不能分割,遇到到了bug。 截取命令: 报错如下: [mp3float @ 0000022b8220d300] Header missing Error while decoding stream #0:1: Invalid data found when processing input [mp3float @ 0000022b8220d300] Header missing Error while decoding stream

    2023年04月10日
    浏览(21)
  • 【音视频】基于ffmpeg对视频的切割/合成/推流

    基于FFmpeg对视频进行切割、合成和推流的价值和意义在于它提供了一种高效、灵活且免费的方式来实现视频内容的定制、管理和分发。通过FFmpeg,用户可以轻松地剪辑视频片段,根据需要去除不必要的部分或提取特定时间段的内容,从而优化观看体验和提高内容的价值。视频

    2024年01月18日
    浏览(54)
  • 使用ffmpeg实现给音频,视频添加水印的操作

    本文主要针对ffmpeg进行整理,从而解决在现实中可能存在的问题。 这里参考的是 Java后台用ffmpeg命令给视频添加水印 - ^身后有尾巴^ - 博客园 (cnblogs.com) 1:先去ffmpeg官网下载其压缩包  Download FFmpeg 下载,解压到指定位置  2.将压缩包拷贝到你想的任意位置并解压,正常解压出

    2023年04月08日
    浏览(28)
  • 【FFmpeg】音视频录制 ① ( 查询系统中 ffmpeg 可录制的音视频输入设备 | 使用 ffmpeg 命令录制音视频数据 | 录制视频数据命令 |录制音频数据| 同时录制音频和视频数据命令 )

    在 Windows 系统中 , 使用 ffmpeg 命令 录制 音视频 , 需要先获取 系统的 音视频设备 信息 , 录制 音视频 本质上是从 系统音视频设备 中获取数据 ; 执行 命令 , 可以获取 系统中 ffmpeg 可用的 DirectShow 音视频输入设备 ; 命令参数解析 : -list_devices true : 列出所有 ffmpeg 的 指定类型的可

    2024年04月25日
    浏览(68)
  • 【HarmonyOS】实现从视频提取音频并保存到pcm文件功能(API6 Java)

     【】 视频提取类Extractor、视频编解码、保存pcm文件 【写在前面】 在使用API6开发HarmonyOS应用时,通常会开发一些音视频媒体功能,这里介绍如何从视频中提取音频保存到pcm文件功能,生成pcm音频文件后,就可使用音频播放类AudioRenderer进行播放了。这里主要介绍从视频

    2024年02月15日
    浏览(26)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包