shell - FFMPEG - 连接 2 个 MP4 文件,一个有视频和音频,另一个只有音频

标签 shell audio video ffmpeg

我正在尝试使用 FFMPEG 合并 2 个 mp4 文件。其中一个文件既有视频又有音频(track1.mp4),而另一个文件只有音频(track2.mp4)。这些文件的名称列在一个名为 'filesToMerge.txt' 的文本文件中。以下列方式:

file 'track1.mp4'
file 'track2.mp4'

然后我执行以下 ffmpeg 命令来合并它们。
ffmpeg -f concat -i filesToMerge.txt -c copy output.mp4

但是,生成的连接文件仅包含 filesToMerge.txt 中列出的第一个文件。 .也就是说,如果 track1.mp4 (同时具有视频和音频)是列表中的第一个文件,然后只有该文件构成 output.mp4(生成的连接文件),反之亦然。

我希望这两个文件都在 output.mp4 中.我正在使用 Ubuntu 14.04(如果有帮助的话)。我怎么解决这个问题?

当我运行这个命令
ffmpeg -i track1.mp4 -i track2.mp4 output.mp4我得到以下
ffmpeg version N-76944-g15206ff Copyright (c) 2000-2015 the FFmpeg developers
      built with gcc 4.8 (Ubuntu 4.8.4-2ubuntu1~14.04)
      configuration: --extra-libs=-ldl --prefix=/opt/ffmpeg --enable-avresample --disable-debug --enable-nonfree --enable-gpl --enable-version3 --enable-libopencore-amrnb --enable-libopencore-amrwb --disable-decoder=amrnb --disable-decoder=amrwb --enable-libpulse --enable-libdcadec --enable-libfreetype --enable-libx264 --enable-libx265 --enable-libfdk-aac --enable-libvorbis --enable-libmp3lame --enable-libopus --enable-libvpx --enable-libspeex --enable-libass --enable-avisynth --enable-libsoxr --enable-libxvid --enable-libvo-aacenc --enable-libvidstab
      libavutil      55.  9.100 / 55.  9.100
      libavcodec     57. 16.101 / 57. 16.101
      libavformat    57. 19.100 / 57. 19.100
      libavdevice    57.  0.100 / 57.  0.100
      libavfilter     6. 17.100 /  6. 17.100
      libavresample   3.  0.  0 /  3.  0.  0
      libswscale      4.  0.100 /  4.  0.100
      libswresample   2.  0.101 /  2.  0.101
      libpostproc    54.  0.100 / 54.  0.100
    Input #0, mov,mp4,m4a,3gp,3g2,mj2, from 'track1.mp4':
      Metadata:
        major_brand     : isom
        minor_version   : 512
        compatible_brands: isomiso2avc1mp41
        encoder         : Lavf56.40.101
      Duration: 00:00:10.76, start: 0.023220, bitrate: 351 kb/s
        Stream #0:0(und): Video: h264 (High) (avc1 / 0x31637661), yuv420p, 800x400 [SAR 400:533 DAR 800:533], 181 kb/s, 25 fps, 25 tbr, 12800 tbn, 50 tbc (default)
        Metadata:
          handler_name    : VideoHandler
        Stream #0:1(und): Audio: aac (LC) (mp4a / 0x6134706D), 44100 Hz, stereo, fltp, 194 kb/s (default)
        Metadata:
          handler_name    : SoundHandler
    Input #1, mov,mp4,m4a,3gp,3g2,mj2, from 'track2.mp4':
      Metadata:
        major_brand     : isom
        minor_version   : 512
        compatible_brands: isomiso2mp41
        creation_time   : 1970-01-01 00:00:00
        encoder         : Lavf52.32.0
      Duration: 00:00:32.21, start: 0.000000, bitrate: 46 kb/s
        Stream #1:0(eng): Audio: aac (LC) (mp4a / 0x6134706D), 48000 Hz, stereo, fltp, 43 kb/s (default)
        Metadata:
          creation_time   : 1970-01-01 00:00:00
          handler_name    : SoundHandler
    [libx264 @ 0x3950ce0] using SAR=400/533
    [libx264 @ 0x3950ce0] using cpu capabilities: MMX2 SSE2Fast SSSE3 SSE4.2 AVX AVX2 FMA3 LZCNT BMI2
    [libx264 @ 0x3950ce0] profile High, level 3.0
    [libx264 @ 0x3950ce0] 264 - core 142 r2491 24e4fed - H.264/MPEG-4 AVC codec - Copyleft 2003-2014 - http://www.videolan.org/x264.html - options: cabac=1 ref=3 deblock=1:0:0 analyse=0x3:0x113 me=hex subme=7 psy=1 psy_rd=1.00:0.00 mixed_ref=1 me_range=16 chroma_me=1 trellis=1 8x8dct=1 cqm=0 deadzone=21,11 fast_pskip=1 chroma_qp_offset=-2 threads=1 lookahead_threads=1 sliced_threads=0 nr=0 decimate=1 interlaced=0 bluray_compat=0 constrained_intra=0 bframes=3 b_pyramid=2 b_adapt=1 b_bias=0 direct=1 weightb=1 open_gop=0 weightp=2 keyint=250 keyint_min=25 scenecut=40 intra_refresh=0 rc_lookahead=40 rc=crf mbtree=1 crf=23.0 qcomp=0.60 qpmin=0 qpmax=69 qpstep=4 ip_ratio=1.40 aq=1:1.00
    Output #0, mp4, to 'output.mp4':
      Metadata:
        major_brand     : isom
        minor_version   : 512
        compatible_brands: isomiso2avc1mp41
        encoder         : Lavf57.19.100
        Stream #0:0(und): Video: h264 (libx264) ([33][0][0][0] / 0x0021), yuv420p, 800x400 [SAR 400:533 DAR 800:533], q=-1--1, 25 fps, 12800 tbn, 25 tbc (default)
        Metadata:
          handler_name    : VideoHandler
          encoder         : Lavc57.16.101 libx264
        Stream #0:1(und): Audio: aac (libfdk_aac) ([64][0][0][0] / 0x0040), 44100 Hz, stereo, s16, 128 kb/s (default)
        Metadata:
          handler_name    : SoundHandler
          encoder         : Lavc57.16.101 libfdk_aac
    Stream mapping:
      Stream #0:0 -> #0:0 (h264 (native) -> h264 (libx264))
      Stream #0:1 -> #0:1 (aac (native) -> aac (libfdk_aac))
    Press [q] to stop, [?] for help
    frame=  270 fps= 99 q=28.0 Lsize=     382kB time=00:00:10.72 bitrate= 291.9kbits/s dup=1 drop=0    
    video:230kB audio:143kB subtitle:0kB other streams:0kB global headers:0kB muxing overhead: 2.482656%
    [libx264 @ 0x3950ce0] frame I:2     Avg QP:18.87  size:109452
    [libx264 @ 0x3950ce0] frame P:68    Avg QP:15.09  size:   171
    [libx264 @ 0x3950ce0] frame B:200   Avg QP:23.33  size:    23
    [libx264 @ 0x3950ce0] consecutive B-frames:  1.1%  0.0%  1.1% 97.8%
    [libx264 @ 0x3950ce0] mb I  I16..4: 11.0% 39.6% 49.5%
    [libx264 @ 0x3950ce0] mb P  I16..4:  0.0%  0.0%  0.0%  P16..4:  5.9%  0.1%  0.0%  0.0%  0.0%    skip:93.9%
    [libx264 @ 0x3950ce0] mb B  I16..4:  0.0%  0.0%  0.0%  B16..8:  0.3%  0.0%  0.0%  direct: 0.0%  skip:99.7%  L0:21.8% L1:78.2% BI: 0.0%
    [libx264 @ 0x3950ce0] 8x8 transform intra:39.7% inter:92.8%
    [libx264 @ 0x3950ce0] coded y,uvDC,uvAC intra: 92.0% 95.0% 73.2% inter: 0.1% 1.4% 0.0%
    [libx264 @ 0x3950ce0] i16 v,h,dc,p:  1% 30%  4% 66%
    [libx264 @ 0x3950ce0] i8 v,h,dc,ddl,ddr,vr,hd,vl,hu:  6% 55% 16%  2%  4%  2%  8%  2%  6%
    [libx264 @ 0x3950ce0] i4 v,h,dc,ddl,ddr,vr,hd,vl,hu: 17% 18% 13%  7%  9%  7% 12%  6% 11%
    [libx264 @ 0x3950ce0] i8c dc,h,v,p: 44% 35% 10% 11%
    [libx264 @ 0x3950ce0] Weighted P-Frames: Y:0.0% UV:0.0%
    [libx264 @ 0x3950ce0] ref P L0: 98.1%  0.2%  1.1%  0.5%
    [libx264 @ 0x3950ce0] ref B L0: 85.1% 13.2%  1.7%
    [libx264 @ 0x3950ce0] ref B L1: 93.6%  6.4%
    [libx264 @ 0x3950ce0] kb/s:174.10

最佳答案

因此,如果我理解正确,您希望最终输出的视频文件播放 track1.mp4,它将有视频和音频,然后是 track2.mp4,它只有音频并且什么都不显示?以下答案假设这是您想要的输出。

我尝试了几种解决方案,即从视频中分离音频并首先连接音频,然后重新合并,并生成与 track2.mp4 一起使用的黑色视频。我无法说服他们工作。我发现 DID 运行良好的最终解决方案是 bash script在 ffmpeg wiki 上的 Concatenate页。

这些步骤非常简单。将 bash 脚本复制到与 track1/2.mp4 位于同一目录中的名为“mmcat”的文件中。然后运行

chmod +x mmcat && ./mmcat track1.mp4 track2.mp4 final.mp4

您现在应该在 final.mp4 中有您想要的文件。

请注意,此方法确实涉及一些转码,因此理论上您这样做会损失一些质量。根据我的实验,我不认为这是可以避免的,因为只有在编解码器完全匹配时才支持流复制,并且您似乎没有处于这种情况(您的音频文件具有不同的比特率、采样率等)。

另请注意,track1 的视频最后一帧中的任何内容都将在 track2 的持续时间内显示并卡住。如果你想让它变黑,你最好确保你在 track1 中的最后一帧是黑帧。这样做一直作为 OP 的练习。

关于shell - FFMPEG - 连接 2 个 MP4 文件,一个有视频和音频,另一个只有音频,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38174585/

相关文章:

python - 我的 librosa MFCC 输出正确吗?我认为使用 librosa MFCC 时得到的帧数错误

audio - 麦克风输入播放(Fmod studio API)

linux - 通过匹配从另一个文件获得的模式替换文件中的字符串

bash - 使用 Bash 比较 PHP 版本号?

audio - 使用 ffmpeg 从 28 分钟的视频中复制 5 秒

ios - 如何使用 Swift 在 iOS 中防止视频放大/缩小?

video - ffmpeg - 将视频组合成一个宽视频

linux - Bash:我无法在双 while 循环中运行 eval 命令

shell - Jenkins 重启 Tomcat

安卓:视频缩略图