私は2つのビデオファイル(flv)を持っています。 1つにはビデオがあり、もう1つにはオーディオがあります。オーディオをmp3として抽出し、それをビデオflvとマージするffmpegを使用してスクリプトを作成しました。オーディオがビデオよりも長いため、オーディオとビデオが同期していないことを除いて、機能します。彼らはビデオの前に会議の音声を録音し始めました。
完全を期すために、ここに私の2つのコマンドがあります。
msg "Extracting Audio"
./ffmpeg -loglevel panic -i cameraVoip*.flv -vn -acodec mp3 output_audio.mp3
msg "Merging Audio with Video"
./ffmpeg -loglevel panic -i output_audio.mp3 -i screenshare*.flv -acodec copy -vcodec copy output_video.flv
これは私に考えさせられました、ffmpegは各ファイルの最初から2つのファイルを一緒に結合しています。最後から一致していると判断し、最初に余分なものを無視する方法はありますか?
各ファイルを編集して同じサイズにすることができることはわかっていますが、これを可能な限り自動化したいと思います。
ffmpeg -i inputfile
を実行するだけで、ストリームの長さを含む情報出力が得られます(ffprobe
コマンドもありますが、同じことを行う場合と行わない場合があります。出力制御)。
% ffmpeg -i foo.mkv
ffmpeg version 1.0.git-79133fd Copyright (c) 2000-2012 the FFmpeg developers
[...]
Input #0, matroska,webm, from 'foo.mkv':
Metadata:
creation_time : 2009-11-08 16:11:10
Duration: 00:43:16.71, start: 0.000000, bitrate: 2435 kb/s
Stream #0:0(eng): Video: h264 (High), yuv420p, 720x480 [SAR 32:27 DAR 16:9], 23.98 fps, 23.98 tbr, 1k tbn, 47.95 tbc (default)
Stream #0:1(eng): Audio: ac3, 48000 Hz, stereo, s16, 192 kb/s (default)
Stream #0:2(eng): Subtitle: subrip
At least one output file must be specified
したがって、この出力を解析して各元のファイルの長さを取得してから、学習した内容で-itsoffset
オプションを使用する必要があります。
-itsoffset offset (input)
Set the input time offset in seconds. "[-]hh:mm:ss[.xxx]" syntax
is also supported. The offset is added to the timestamps of the
input files. Specifying a positive offset means that the
corresponding streams are delayed by offset seconds.
したがって、(テストされていない)のようなものになります:
ffmpeg -i foo.mp3 -itsoffset 60 -i blah.mpeg -acodec copy -vcodec copy -copyts out.mkv