ffmpeg concat video and mix audio

2019-12-19 00:04:44

参考地址 https://www.jianshu.com/p/0109e53fafd5

需求

将N个片段视频文件连接,并合并额外的音频文件

解决方案:

ffmpeg中,官网给出两种连接媒体文件(音频、视频、etc..)的解决方案。

  • the concat "demuxer"

  • the concat "protocol"

对比而言, demuxer更加灵活一些,需要媒体文件是属于相同的编解码器,但是可以属于不同的容器格式(mp3,wav, mp4, mov, etc..).
protocol只适用于少数集中容器格式。

使用concat demuxer连接视频文件

demuxer从一个文本文件中读取文件或者其他指令的列表,然后注意的对他们进行解复用。就像把他们的数据包混合到一起。

步骤:

1.创建一个文件mylist.txt,包含你想要连接的所有文件,格式如下:

file 'path/to/file1'
file 'path/to/file2'
file 'path/to/file3'

其中的文件路径可以是相对路径或者是绝对路径。

2.ffmpeg命令

ffmpeg -f concat -safe 0 -i mylist.txt -c copy output

如果对应的路径为相对路径 参数-safe 0就不是必须的。

3.自动生成输入文本文件的

可以使用如下shell脚本生成。

# with bash or zsh for loop
for f in *.mp4; do echo "file '$f'" >> mylist.txt; done
# or with printf
printf "file '%s'\n" *.mp4 > mylist.txt

使用Concat protocol 连接视频文件

demuxer 是在文件流级别工作,而cancat protocol则是在文件级别操作。
可以将使用MPEG-2传输流的文件连接在一起。类似于在类unix系统上使用cat,或在windows系统上使用copy.

1.下面的命令连接了三个MPEG-2 TS文件,并将它们连接在一起,但不进行重编码

ffmpeg -i "concat:input1.ts|input2.ts|input3.ts" -c copy output.ts

2.使用中间文件

ffmpeg -i input1.mp4 -c copy -bsf:v h264_mp4toannexb -f mpegts intermediate1.ts
ffmpeg -i input2.mp4 -c copy -bsf:v h264_mp4toannexb -f mpegts intermediate2.ts
ffmpeg -i "concat:intermediate1.ts|intermediate2.ts" -c copy -bsf:a aac_adtstoasc output.mp4

3.使用命名管道避免中间文件

mkfifo temp1 temp2
ffmpeg -i input1.mp4 -c copy -bsf:v h264_mp4toannexb -f mpegts temp1 2> /dev/null & \
ffmpeg -i input2.mp4 -c copy -bsf:v h264_mp4toannexb -f mpegts temp2 2> /dev/null & \
ffmpeg -f mpegts -i "concat:temp1|temp2" -c copy -bsf:a aac_adtstoasc output.mp4

所有MPEG格式(MPEG-4 Part 10 / AVC, MPEG-4 Part 2, MPEG-2 Video, MPEG-1 Audio Layer II,
MPEG-2 Audio Layer III (MP3), MPEG-4 Part III (AAC)).都可以转换成MPEG-TS.但是其中的一些参数需要改变,比如-bsf比特流过滤器需要改变

合并音频和视频

默认情况下,ffmpeg只会处理一个音频流和一个视频流,

先给命令:

ffmpeg -i input.mp4 -i input.mp3 -c copy -map 0:v:0 -map 1:a:0 output.mp4

相关解释:

  • map 参数制指定了从哪一个输入流中映射到输出中。

  • 0:v:0 从第一个输出文件中取第一个视频流,1:a:0从第二个文件中取第一个音频流。 v/a参数不是必需的。
    但是如果输入文件中包含多个流,这样有助于消除歧义。

  • 如果你的音频流时长超过视频流,或者相反,你可以使用-shortest参数,使ffmpeg参数在处理到两个输入短的结束时结束。

  • -c copy 复制音频流和视频流,这意味着进程会处理的更快,并且质量也与之前一样。但是在添加一个wav音频到视频中时,最好先
    压缩一下音频。例如:
    ffmpeg -i input.mp4 -i input.wav -c:v copy -map 0:v:0 -map 1:a:0 -c:a aac -b:a 192k output.mp4
    命令中,我们复制了视频流,但是使用ffmpeg内置的AAC编码器重编码了音频,设置为了192kBit/s.

  • 如果你的输出并不支持特定的编解码器, 例如(添加WAV到MP4,或者AAC到AVI中)重编码也是需要的。

我的解决方案:

由于需要合并片段文件和相应的音频文件,首先会拆离视频文件中的音频文件, 并与另外的音频文件混合。可以使用sox或者ffmpeg

然后在执行连接命令。

命令如下:

ffmpeg -hide_banner -f concat -i list.txt -i if.mp3 -c:v copy -c:a aac -strict -2 -map 0:v:0 -map 1:a:0  test.mp4

参考资料:




  • 2020-01-10 22:00:23

    又一款内网穿透工具搭建

    最近一个项目需要用到将订单发布到第三方平台,之后要是有人购买他们会请求我们这边的接口来改变订单状态等! 由于本地开发,测试的时候,他们那边请求我们这边接口的时候没法访问内网 所以要用到内网穿透 当然现在也有很多更简单的 比如花生壳就是很好的!

  • 2020-01-13 11:14:43

    p标签中的文本换行显示空白

    white-space: 如何处理元素中的空白,normal: 默认, 被浏览器忽略空白 pre: 空白被浏览器保留. nowrap: 文本不会换行, 会在同一行上继续, 一直走到需要换行为止 pre-wrap: 保留空白符序列, 但正常换行 pre-line: 合并空白符序列, 但正常换行 inherit: 从父元素继承white-space这个属性

  • 2020-01-13 11:26:40

    Ueditor报错not import language file vue

    解决办法,手动加载语言文件,提供了手动加载语言文件,避免ie下有时会因语言文件加载失败导致编辑器加载失败,提示"not import language file"的错误

  • 2020-01-13 11:30:56

    解决Uncaught SyntaxError: Unexpected token <

    今天写代码的时候发现了"Uncaught SyntaxError: Unexpected token <" <html>的js错误,而且还是html的第一行,我就蒙了,这第一行有啥问题啊,还有一个“<”符号,我以为是我的网页标签没有闭包,所以检查了一下,都不是啊!错误如图。

  • 2020-01-13 14:53:51

    sass中使用calc计算表达式变量问题

    calc()是css的一个函数,可用于元素计算长度,比如div宽度想要减去一个固定宽度后并自适应,可以写为calc(100% - 60px) 注意“-”两边有空格 sass已经是常用的预编译语言,允许使用变量等规则,如果上边写到60px是一个变量,这个表达怎么写呢

  • 2020-01-13 21:01:04

    vue路由的异步加载(懒加载)方法

    vue本身不多介绍。直接说问题,因为vue的所有路由都是加载在一个app.js里的,如果项目巨大,那么首页加载会是灾难。所以我们就需要把某些路由用异步加载(懒加载)的方式进行加载.

  • 2020-01-13 21:56:45

    Ant Design Pro nginx配置

    Ant Design Pro nginx配置 今天看了下Ant和nginx的配置 给大家分享下 下边的配置可以直接使用 修改为自己的域名和文件夹目录就可以