heracl.es

/montaziera

A video-editing tool, using ffmpeg, PowerShell, and a CSV spreadsheet.

Montaziera (a play on the equivalent of “montagiere” in Greek) is a video-editing tool, that creates a preview or a rough cut using ffmpeg, PowerShell, and a CSV spreadsheet with timecodes.

Its purpose is to quickly generate feedback for peers that can indicate preffered segments from a video, without having to use Premiere or other complex editors. The resulting MP4 files are 640x360 (unless you modify the script) and will not be frame-perfect.

Requirements

  • PowerShell; a scripting language available by default on Windows 10 installations. It’s also possible to install it on macOS.
  • ffmpeg; an open-source command-line tool for editing video. You will have to install a Windows build manually. It’s important for ffmpeg executable to be added to the Path.
  • Any spreadsheet editor (such as Microsoft Excel, Google Sheets, LibreOffice Calc etc.) that can export CSV files.
  • Download all the files from this repository in the same directory (folder).
[i18n] caution

Always beware of scripts you find available online: open them in a text editor and inspect what they do.

How to run

  • Make sure you have saved your CSV file in the same directory as timecodes.csv. See Spreadsheet structure for more.
  • Double-click montaziera_run.bat, to execute a simple BAT script that will open a console window and run the respective montaziera.ps1 PowerShell script.
  • After some time, unless an error occurs, an MP4 file with your desired cut will be available in the same directory.
  • If an error occurs, it will appear in red text on the console window.

Your working directory will eventually look similar to this:

├── /clips/			(generated automatically)
│   ├── 000.mp4
│   ├── …
│   timecodes.csv		(created by user)
│   concat.txt			(generated automatically)
│   montaziera_run.bat		(double click to run)
│   montaziera.ps1		(the actual script)
│   preview_2020-09-10-11.mp4	(the output video)
[i18n] note

If that doesn’t look like your setup in Windows, then it helps to enable the display of file extentions.

How it works

  • The script reads the CSV file line by line, and cuts segments in a directory named /clips/ as directed by the start and duration columns. The directory will be created if it doesn’t exist.
  • A short white clip is inserted first to ensure the resulting video has audio, to counter a shortcoming of ffmpeg.
  • Once the segmenst have been created, the clips are “glued” together according to the order they appear in concat.txt, a simple text file created during the previous steps.
  • If a super and desc (description) is provided for a line, its text contents will be overlaid on the video at bottom left. The name of each clip file (a three-digit number) is displayed in the upper right corner. This is designed to help identify which segment is which.
[i18n] important

You will have to manually delete the /clips/ directory if you wish to re-generate them, therefore always delete it if you wish to change your CSV file. However its useful in case an error occurs, as not every segment has to be processed from scratch.

Spreadsheet structure

Your sheet should have the following structure. Export it as a CSV (comma separated) and save it on the same directory with the script as timecodes.csv. A sample file is provided here, named timecodes_sample.csv.

materialfilestartenddurationsuperdescr
some videoC:/…/documents/video01.mp400:05:0000:08:2000:03:20Moderator’s NameDescription of segment
an imageC:/…/documents/card.png00:00:0000:00:1000:00:10IntroductionA static card
other videoC:/…/documents/video02.mp400:10:4000:12:0000:01:20Speaker’s nameFirst segment
other videoC:/…/documents/video02.mp400:20:0000:22:1000:02:10Second segment
  • The material column text is optional, but the column itself is required. It serves as a note of the file column contents.
  • The file (accepts MP4, MOV, JPG and PNG) to be edited may be anywhere on your computer, but you will have to provide the exact path and filename. The CSV file should not contain any headers, ie. the line that describes what the columns are.
  • Timecodes and durations are in hours:minutes:seconds.milliseconds format. However milliseconds are optional. The end timecode is currently ignored, but the column itself is required.
  • Text in the super and descr column will be rendered over the video.
[i18n] note

This script is alpha quality, hence it will not tolerate mistakes in your CSV. It’s helpful to use formulas to make sure the durations are correct, thefore you may want to use an advanced spreadsheet format and then export into CSV format. In Microsoft Excel, the respective formula is: =TEXT(B2-A2,"h:mm:ss")

Known issues / Future Improvements

  • If several video sources are mixed, audio-video may become out of sync.
  • Non-latin characters in the super and description column, may sometimes cause the overlay to be hidden.
  • Clips created from static images may have the wrong duration.
  • Missing option to select the output definition.
  • Missing option to hide text overlays.
  • Missing a prompt to delete (or keep) previously generated clips.
  • Missing option to select duration (currently) or end timecode for clipping videos.
  • Code could be cleaner / modular. Pull Requests are welcome.
  • Additional ffmpeg filters could be passed per line.
  • Progress indicator (display which line of … many).

© 2020 Heracles Papatheodorou a.k.a @heracles, MIT Licence