Small Python CLI application to fill missing metadata of images based on the filename. This tool takes advantage of the filename structure to infer and correct metadata attributes for each image. The CLI offers various options to control the behavior of the correction process.
Example filename structures:
- 20151127_074841.jpg
- IMG_20160908_115420.jpg
- Screenshot_20171228-111228.png
- IMG-20160714-WA0001.jpg
- 2014-07-25 14.54.55.jpg
Managing and organizing a large collection of images can be a challenging task, especially when dealing with missing or incorrect metadata. I noticed that some of my images had missing metadata, but the correct date was present in the filename. So I decided to write a small CLI application to correct the metadata based on the filename.
Before using the program, you need to have Python and pip installed on your system. You can then install the CLI using the following steps:
- Clone this repository or download the source code.
- Open a terminal and navigate to the root directory of the repository.
- Run the following command to install the required dependencies:
pip install -r requirements.txt
The application provides several options to customize the correction process. Here is the usage information for each parameter and option:
Usage: img_date_fixer [OPTIONS] ORIGINAL_DIR [CORRECTED_DIR]
Correct image dates in the metadata and copy the images to the corrected
directory.
Options:
--clean Delete the corrected directory if it already exists.
--inplace Overwrite the original images with the corrected images.
--dry-run Does not change the image metadata, but logs the changes that
would be made.
--help Show this message and exit.
ORIGINAL_DIR
: The path to the directory containing the original images with missing metadata.CORRECTED_DIR
(optional): The path to the directory where corrected images will be saved. Default is"data/corrected/"
.
--clean
: If this flag is provided, the contents of theCORRECTED_DIR
will be deleted before saving corrected images.--inplace
: If this flag is provided, the original images will be overwritten with the corrected images.--dry-run
: If this flag is provided, no actual changes will be made to the images. Instead, the CLI will log the changes that would be made.
- Basic usage with default settings:
img_date_fixer /path/to/original/images/
- Specifying the corrected directory and using the inplace option:
img_date_fixer --inplace /path/to/original/images/ /path/to/corrected/images/
- Performing a dry run to see the changes without actually modifying the images:
img_date_fixer --dry-run /path/to/original/images/
- The CLI uses the filename structure to infer and correct metadata attributes. Make sure your filenames are appropriately formatted for accurate metadata correction.
- Always make sure to have backups of your original images before performing any modifications.
- The CLI may not be able to accurately correct all metadata attributes. Review the changes carefully before applying them to your images.
This project is licensed under the MIT License - see the LICENSE file for details.
Feel free to reach out for any issues, suggestions, or contributions.