Easily create a video montage (either a sequence or a grid of videos)
Project description
video_montage
Easily create a video montage (either a sequence or a grid of videos)
Installing
Install:
pip install video_montage
Usage
Before running, you must have a prepare an input video folder with videos the following structure, eg.
<INPUT_VIDEO_FOLDER_PATH>
├── <video1>.mp4
├── <video2>.mp4
└── ...
video_grid_montage: Create a grid of videos (all playing at the same time). If the videos are not all the same length, the video length will default to using the longest video, and filling the other videos with a freeze of the last frame.
video_grid_montage --help
usage: video_grid_montage --input_video_folder_path INPUT_VIDEO_FOLDER_PATH [--output_video_folder_path OUTPUT_VIDEO_FOLDER_PATH]
[--output_video_filename OUTPUT_VIDEO_FILENAME] [--max_n_videos MAX_N_VIDEOS] [--montage_duration_seconds MONTAGE_DURATION_SECONDS]
[--fps FPS] [--num_per_row NUM_PER_ROW] [--overlay_filename] [--fill_mode {freeze,loop,black}] [-h]
optional arguments:
--input_video_folder_path INPUT_VIDEO_FOLDER_PATH
(Path, required)
--output_video_folder_path OUTPUT_VIDEO_FOLDER_PATH
(Path, default=.)
--output_video_filename OUTPUT_VIDEO_FILENAME
(Union[str, NoneType], default=None)
--max_n_videos MAX_N_VIDEOS
(Union[int, NoneType], default=None)
--montage_duration_seconds MONTAGE_DURATION_SECONDS
(Union[float, NoneType], default=None)
--fps FPS (Union[int, NoneType], default=None)
--num_per_row NUM_PER_ROW
(Union[int, NoneType], default=None)
--overlay_filename (bool, default=False)
--fill_mode {freeze,loop,black}
(Literal['freeze', 'loop', 'black'], default=freeze)
-h, --help show this help message and exit
video_sequence_montage: Create a sequence of videos (playing one at a time sequentially)
video_sequence_montage --help
usage: video_sequence_montage --input_video_folder_path INPUT_VIDEO_FOLDER_PATH
[--output_video_folder_path OUTPUT_VIDEO_FOLDER_PATH]
[--output_video_filename OUTPUT_VIDEO_FILENAME]
[--max_n_videos MAX_N_VIDEOS] [--fps FPS]
[--overlay_filename] [-h]
optional arguments:
--input_video_folder_path INPUT_VIDEO_FOLDER_PATH
(Path, required)
--output_video_folder_path OUTPUT_VIDEO_FOLDER_PATH
(Path, default=.)
--output_video_filename OUTPUT_VIDEO_FILENAME
(str, default=2023-10-20_00-17-06_video_sequence_montage.mp4)
--max_n_videos MAX_N_VIDEOS
(Union[int, NoneType], default=None)
--fps FPS (Union[int, NoneType], default=None)
--overlay_filename (bool, default=False)
-h, --help show this help message and exit
Example Usage
(video_montage_env) ➜ video_montage git:(main) ✗ tree openai_rubiks_cube
openai_rubiks_cube
├── 2023-10-07_20-04-36_openai_rubiks_cube.gif
├── 2023-10-07_20-05-13_openai_rubiks_cube.gif
├── 2023-10-07_20-05-48_openai_rubiks_cube.gif
├── 2023-10-07_20-07-27_openai_rubiks_cube.gif
├── 2023-10-07_20-08-02_openai_rubiks_cube.gif
└── 2023-10-07_20-11-18_openai_rubiks_cube.gif
0 directories, 6 files
(video_montage_env) ➜ video_montage git:(main) ✗ video_grid_montage --input_video_folder_path openai_rubiks_cube
Moviepy - Building video 2023-10-07_20-16-08_video_grid_montage.mp4.
Moviepy - Writing video 2023-10-07_20-16-08_video_grid_montage.mp4
Moviepy - Done !
Moviepy - video ready 2023-10-07_20-16-08_video_grid_montage.mp4
You can also add the --overlay_filename argument to add the clip's filename to each video clip.
If you get an error related to ImageMagick, you can try running the following command to fix it:
sudo apt-get install imagemagick
or
conda install -c conda-forge imagemagick
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file video_montage-0.2.1.tar.gz.
File metadata
- Download URL: video_montage-0.2.1.tar.gz
- Upload date:
- Size: 6.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.9.21
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
7905382c3a876fecaf09cd071343dcdec1ce8c99675f3fe5444998d27fc1980f
|
|
| MD5 |
c5d11a699708caac939d73a4990f0298
|
|
| BLAKE2b-256 |
c53762856730105d207192a392af8484ddaa417a2a0d06a115736ea34c29a3c3
|
File details
Details for the file video_montage-0.2.1-py3-none-any.whl.
File metadata
- Download URL: video_montage-0.2.1-py3-none-any.whl
- Upload date:
- Size: 7.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.9.21
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4505dd51a773ca8e22f267bbf5156c70860477f7f7233e3b2bc6916c2a676c6c
|
|
| MD5 |
ee99d648c1c65f01fcee7e2aa207eea6
|
|
| BLAKE2b-256 |
75a51f2f4e2fde6db192f6096d07b8bbe0c62ef32677edad9a5029e236fb60d9
|