Jawaban:
ffprobe -i some_video -show_entries format=duration -v quiet -of csv="p=0"
akan mengembalikan durasi video dalam hitungan detik.
Sesuatu yang mirip dengan:
ffmpeg -i input 2>&1 | grep "Duration"| cut -d ' ' -f 4 | sed s/,//
Hal ini akan memberikan: HH:MM:SS.ms
. Anda juga dapat menggunakan ffprobe
, yang disediakan dengan sebagian besar instalasi FFmpeg:
ffprobe -show_format input | sed -n '/duration/s/.*=//p'
… atau:
ffprobe -show_format input | grep duration | sed 's/.*=//')
Untuk mengkonversi menjadi detik (dan mempertahankan milidetik), pipa menjadi:
awk '{ split($1, A, ":"); print 3600*A[1] + 60*A[2] + A[3] }'
Untuk mengubahnya menjadi milidetik, pipa menjadi:
awk '{ split($1, A, ":"); print 3600000*A[1] + 60000*A[2] + 1000*A[3] }'
Jika Anda hanya menginginkan detik tanpa milidetik, sambungkan ke:
awk '{ split($1, A, ":"); split(A[3], B, "."); print 3600*A[1] + 60*A[2] + B[1] }'
Contoh:
ffprobe
, alat yang dirancang untuk tujuan semacam ini yang dikemas dengan ffmpeg
: ffprobe -show_format input | sed -n '/duration/s/.*=//p'
(atau ffprobe -show_format input | grep duration | sed 's/.*=//'
). Mungkin @slhck dapat mengedit ini langsung ke jawabannya.
Jika Anda tidak memiliki akses ffprobe
, Anda bisa menggunakan mediainfo
.
# Outputs a decimal number in seconds
mediainfo some_video --Output=JSON | jq '.media.track[0].Duration' | tr -d '"'`
jq
dan tr
:mediainfo --Output="General;%Duration/String%" input
X s YYY ms
versus X.YYY
. Cukup mudah disesuaikan dengan | sed -e 's/ s /./' -e 's/ ms//'
jika Anda ingin pergi ke rute itu dan tidak memiliki akses ke jq
.
mediainfo --Output="General;%Duration/String3%" input
menjadi output 00:01:48.501
bukan 1 min 48 s
.