Opened 12 days ago

Last modified 12 days ago

#11202 new defect

indices with strftime are incompatible.

Reported by: elias tsolis Owned by:
Priority: normal Component: ffmpeg
Version: 6.1.1 Keywords: timestamp, filename
Cc: Blocked By:
Blocking: Reproduced by developer: no
Analyzed by developer: no

Description (last modified by elias tsolis)

command:
ffmpeg -rtbufsize 100M -vsync 0 -vf "select='$frms'" -fps_mode passthrough -strftime 1 frames/"%Y-%m-%d_%H-%M-%S_%5d.bmp" -i "${vid_scr}"

problem:
extracting multiple frames from multiple splitted videos, in automated way using ffmpeg, in an ordered way, with timestamp+increment of index is impossible. Think of multiple videos (vid01.mp4 vid02.mp4) recorded at 50 fps / 128 etc.

When you try to extract these thumbnails all will start as "00001.jpg, 00002.jpg". which will overwrite them. Otherwise you must make a differect directory for each video which is inconvenient.

I have read that strftime cannot work with miliseconds or with other incremented indices.

So this is a problem.

Solution
strftime must define only time and must work with other incremental indices. Also, it must support miliseconds & nanoseconds. There are some addons that do that.

I tried to set the time outside ffmpeg as variable but do not "renew" it. it stuck on same number.

dtmil="$(date +"%T.%N")";

ffmpeg -rtbufsize 100M -vsync 0 -vf "select='$frms'" -fps_mode passthrough frames/"$dtmil_%5d.bmp" -i vid01.mp4

system: linux debian

ffmpeg version 6.1.1-4+b4 Copyright (c) 2000-2023 the FFmpeg developers
  built with gcc 13 (Debian 13.3.0-1)
  configuration: --prefix=/usr --extra-version=4+b4 --toolchain=hardened --libdir=/usr/lib/x86_64-linux-gnu --incdir=/usr/include/x86_64-linux-gnu --arch=amd64 --enable-gpl --disable-stripping --disable-omx --enable-gnutls --enable-libaom --enable-libass --enable-libbs2b --enable-libcaca --enable-libcdio --enable-libcodec2 --enable-libdav1d --enable-libflite --enable-libfontconfig --enable-libfreetype --enable-libfribidi --enable-libglslang --enable-libgme --enable-libgsm --enable-libharfbuzz --enable-libmp3lame --enable-libmysofa --enable-libopenjpeg --enable-libopenmpt --enable-libopus --enable-librubberband --enable-libshine --enable-libsnappy --enable-libsoxr --enable-libspeex --enable-libtheora --enable-libtwolame --enable-libvidstab --enable-libvorbis --enable-libvpx --enable-libwebp --enable-libx265 --enable-libxml2 --enable-libxvid --enable-libzimg --enable-openal --enable-opencl --enable-opengl --disable-sndio --enable-libvpl --disable-libmfx --enable-libdc1394 --enable-libdrm --enable-libiec61883 --enable-chromaprint --enable-frei0r --enable-ladspa --enable-libbluray --enable-libjack --enable-libpulse --enable-librabbitmq --enable-librist --enable-libsrt --enable-libssh --enable-libsvtav1 --enable-libx264 --enable-libzmq --enable-libzvbi --enable-lv2 --enable-sdl2 --enable-libplacebo --enable-librav1e --enable-pocketsphinx --enable-librsvg --enable-libjxl --enable-shared
  libavutil      58. 29.100 / 58. 29.100
  libavcodec     60. 31.102 / 60. 31.102
  libavformat    60. 16.100 / 60. 16.100
  libavdevice    60.  3.100 / 60.  3.100
  libavfilter     9. 12.100 /  9. 12.100
  libswscale      7.  5.100 /  7.  5.100
  libswresample   4. 12.100 /  4. 12.100
  libpostproc    57.  3.100 / 57.  3.100

Change History (2)

comment:1 by elias tsolis, 12 days ago

Description: modified (diff)

comment:2 by elias tsolis, 12 days ago

Description: modified (diff)
Note: See TracTickets for help on using tickets.