オーディオ ファイルの複数のセクションをトリミングして連結しようとしています。何度か検索した結果、これが機能しているようでした。
ffmpeg -i dd.3gpp -filter_complex "[0]atrim=start=00:00:00.060:end=00:00:46.580[a];[0]atrim=start=00:0:50.250:end=00:01:50.670[b];[a][b]concat=n=2:v=0:a=1" output.mp3
しかし、すぐに、トリミングされたセクション間の間隔が短い場合にのみ機能することがわかりました。2番目のトリミングされたセクションのタイムスタンプを次のように変更します。
ffmpeg -i dd.3gpp -filter_complex "[0]atrim=start=00:00:00.060:end=00:00:46.580[a];[0]atrim=start=00:03:23.250:end=00:06:50.670[b];[a][b]concat=n=2:v=0:a=1" output.mp3
このエラーが繰り返し発生します。
[out_0_0 @ 000001df0a98d6c0] 100 個のバッファが out_0_0 にキューイングされています。何か問題がある可能性があります。[out_0_0 @ 000001df0a98d6c0] 1000 個のバッファが out_0_0 にキューイングされています。何か問題がある可能性があります。
ffmpeg version git-2019-12-12-f58bda6 Copyright (c) 2000-2019 the FFmpeg developers
built with gcc 9.2.1 (GCC) 20191125
configuration: --enable-gpl --enable-version3 --enable-sdl2 --enable-fontconfig --enable-gnutls --enable-iconv --enable-libass --enable-libdav1d --enable-libbluray --enable-libfreetype --enable-libmp3lame --enable-libopencore-amrnb --enable-libopencore-amrwb --enable-libopenjpeg --enable-libopus --enable-libshine --enable-libsnappy --enable-libsoxr --enable-libtheora --enable-libtwolame --enable-libvpx --enable-libwavpack --enable-libwebp --enable-libx264 --enable-libx265 --enable-libxml2 --enable-libzimg --enable-lzma --enable-zlib --enable-gmp --enable-libvidstab --enable-libvorbis --enable-libvo-amrwbenc --enable-libmysofa --enable-libspeex --enable-libxvid --enable-libaom --enable-libmfx --enable-ffnvcodec --enable-cuvid --enable-d3d11va --enable-nvenc --enable-nvdec --enable-dxva2 --enable-avisynth --enable-libopenmpt --enable-amf
libavutil 56. 36.101 / 56. 36.101
libavcodec 58. 65.100 / 58. 65.100
libavformat 58. 35.101 / 58. 35.101
libavdevice 58. 9.101 / 58. 9.101
libavfilter 7. 68.100 / 7. 68.100
libswscale 5. 6.100 / 5. 6.100
libswresample 3. 6.100 / 3. 6.100
libpostproc 55. 6.100 / 55. 6.100
Input #0, mov,mp4,m4a,3gp,3g2,mj2, from 'dd.3gpp':
Metadata:
major_brand : 3gp4
minor_version : 0
compatible_brands: isom3gp4
creation_time : 2019-12-14T18:42:01.000000Z
com.android.version: 7.0
Duration: 00:08:46.06, start: 0.000000, bitrate: 129 kb/s
Stream #0:0(eng): Audio: aac (LC) (mp4a / 0x6134706D), 48000 Hz, stereo, fltp, 128 kb/s (default)
Metadata:
creation_time : 2019-12-14T18:42:01.000000Z
handler_name : SoundHandle
Stream mapping:
Stream #0:0 (aac) -> atrim
Stream #0:0 (aac) -> atrim
concat -> Stream #0:0 (libmp3lame)
Press [q] to stop, [?] for help
Output #0, mp3, to 'output.mp3':
Metadata:
major_brand : 3gp4
minor_version : 0
compatible_brands: isom3gp4
com.android.version: 7.0
TSSE : Lavf58.35.101
Stream #0:0: Audio: mp3 (libmp3lame), 48000 Hz, stereo, fltp (default)
Metadata:
encoder : Lavc58.65.100 libmp3lame
size= 170kB time=00:00:10.84 bitrate= 128.5kbits/s speed=21.7x
size= 256kB time=00:00:19.77 bitrate= 106.0kbits/s speed=19.7x
size= 256kB time=00:00:28.17 bitrate= 74.4kbits/s speed=18.7x
size= 512kB time=00:00:39.69 bitrate= 105.7kbits/s speed=19.8x
[out_0_0 @ 000001df0a98d6c0] 100 buffers queued in out_0_0, something may be wrong.
[out_0_0 @ 000001df0a98d6c0] 1000 buffers queued in out_0_0, something may be wrong.
size= 1280kB time=00:01:33.09 bitrate= 112.6kbits/s speed=22.9x
size= 1521kB time=00:01:37.27 bitrate= 128.1kbits/s speed=22.9x
video:0kB audio:1520kB subtitle:0kB other streams:0kB global headers:0kB muxing overhead: 0.023446%
何か間違っているのでしょうか? ご提案はすべて歓迎いたします。
答え1
しばらく2つのコードをいじってみたところ、
ffmpeg -i dd.3gpp -filter_complex "[0]atrim=start=00:00:00.060:end=00:00:46.580[a];[0]atrim=start=00:0:50.250:end=00:01:50.670[b];[a][b]concat=n=2:v=0:a=1" output.mp3
ffmpeg -i dd.3gpp -filter_complex "[0]atrim=start=00:00:00.060:end=00:00:46.580[a];[0]atrim=start=00:03:23.250:end=00:06:50.670[b];[a][b]concat=n=2:v=0:a=1" output.mp3
バッファ エラーは、2 つのトリム間の時間間隔が短いかどうかとは関係ないようです。
むしろ、フォーマットタイムスタンプが問題だったようです。タイムスタンプをS+[.m...]
ではなく に変更しました。[HH:]MM:SS[.m...]
ffmpeg -i dd.3gpp -filter_complex "[0]atrim=start=0.060:end=46.580[a];[0]atrim=start=203.250:end=410.670[b];[a][b]concat=n=2:v=0:a=1" output.mp3
そして、エラーはもう表示されません。最初のコードは、すべてのタイムスタンプが秒の列 ( 00:00:ss.m..
) 内に収まっているため、正常に機能したと思います。この場合、フォーマットがなぜ重要なのか、私にはまったくわかりません。ここの専門家なら、もっとうまく説明できるかもしれません。
答え2
この問題の原因は、filter_complex によって引数を区切るためにコロン ":" が使用されていることです。そのため、これをエスケープする必要があります。
素晴らしい回答https://superuser.com/a/1145796
次の文字エスケープ ソリューションを提供します。
"trim=start='00\:00\:01.23':end='00\:00\:04.56'" "trim=start=00\\\:00\\\:01.23:end=00\\\:00\\\:04.56" trim=start=00\\\\:00\\\\:01.23:end=00\\\\:00\\\\:04.56
楽しむ!