Skip to content

CLI for quick image metadata extraction.

Notifications You must be signed in to change notification settings

Avaray/metadata-extractor-cli

Repository files navigation

🧬 Image Metadata Extractor CLI

Build and Release

A command-line interface (CLI) application that extracts metadata from image files.
This tool is designed for developers who need to quickly access metadata from images in various formats.

Features

  • Extracts metadata from single image or all images in a specified directory (also recursively).
  • Outputs the extracted metadata to console as JSON or saves it to a JSON file.
  • Supports various image formats.

Technologies and Libraries Used

Usage

  1. Download the latest release from the Releases page.
    You need to have .NET 8.0 installed on your machine if you want to use no-runtime version.
  2. Extract executable file from the downloaded archive.
  3. Navigate to the directory where you extracted the files.
  4. Run the following command to get list of available commands:
extractor -h

Available Commands

  • Single Image: Extract metadata from a single image file.
extractor <file-path>
  • Directory: Extract metadata from all images in a specified directory.
extractor -d <directory-path>
  • Directory Recursive: Extract metadata from all images in a specified directory and all subdirectories.
extractor -d <directory-path> -r
  • Output to File: Save the extracted metadata to a JSON file.
extractor <file-path> -o <output-file>

Experimental Options

These options are experimental and might not work as expected. Pretty sure they will be changed or removed in future versions. Combining them together might not work.

  • Filter Tag Name: Return metadata with specific tag name. Ignore all other tags.
extractor -d <directory-path> -t <tag-name>
  • Search in Tag Description: Return metadata with description containing specific string. Ignore all other tags. Using Regex is possible, but might not work as expected. Something like -s '[\d\w]{10}' should work.
extractor -d <directory-path> -s <search-string>

Development

  1. Prerequisites: Ensure you have the .NET SDK (version 8.0 or higher) installed on your machine. You can download it from the official .NET website. You can check your current version by running the following command:
dotnet --version
  1. Clone the Repository:
git clone https://github.com/Avaray/image-metadata-extractor-cli.git
cd image-metadata-extractor-cli
  1. Run the Application:
dotnet run
  1. Build the Application:
dotnet build

About this Project

I created this project because I needed a tool like this. I will use it in my other project where I need to extract metadata from images. Normally I don't code in C# but with help of Claude and Perplexity it was pretty easy 👌

Creating a working CLI took me a little over an hour. However, messing around with configuring GitHub Actions for Releases drove me crazy. But finally, I got it working 🎉

I might add more features in the future. I'm considering following changes:

  • Add recursive metadata extraction -r option.
  • Add checks for invalid file types.
  • Possibility to filter images by "Tag Name".
  • Possibility to filter images by searching in "Tag Description"
  • Lower the required .NET version. Not sure how low I can go.