Skip to main content

A simple EXIF metadata viewer and editor.

Project description

ExifPlus

PyPI version Python versions License Tests Documentation Status

ExifPlus - Short Description & ReadMe

ExifPlus is a versatile and user-friendly metadata viewer and editor for image and video files. It allows you to view and modify EXIF, IPTC, and XMP metadata, making it an essential tool for photographers, videographers, and anyone who needs to manage media metadata easily. With a sleek GUI powered by ttkbootstrap and advanced functionality through libraries like pyexiv2, hachoir, and exifread, ExifPlus makes it simple to interact with file metadata in just a few clicks.


ReadMe & Instruction Manual

ExifPlus - Metadata Viewer and Editor

Overview

ExifPlus is a modern and intuitive tool designed for managing metadata in image and video files. Whether you're a photographer looking to adjust your photo's metadata or a content creator dealing with video files, ExifPlus offers powerful features to read and modify various types of metadata like EXIF, IPTC, and XMP.

Key Features

  • Read and Edit EXIF, IPTC, XMP and other metadata from images and videos. (Right Now Windows doesnt support Edit mode, also doesnt Supports IPTC and XMP.)
  • User-friendly GUI built with tkinter and ttkbootstrap for a sleek and responsive interface.
  • Supports multiple media formats including .jpg, .png, .tiff, .heic, .mp4, .avi, .mov, and .mkv.
  • Batch processing to edit metadata across multiple files (future versions).
  • Save changes to metadata and overwrite the original file.
  • Context Menu with an option to delete rows of metadata for easy data management, or add new rows.
  • Export the data as CSV or JSON
  • Open From URL or Local File Now you can directly upload images from URL or still choose your Local File
  • Generate Reports that are formatted in HTML and ready for submission to platforms such as Bugcrowd or HackerOne.
  • Cross-platform support (Windows, macOS, Linux).

Installation

You can install ExifPlus directly from PyPI using pip. To install the package, simply run the following command in your terminal or command prompt:

pip install exifplus

Ensure that you have the required dependencies installed for full functionality:

  • pyexiv2 (for metadata extraction and editing)
  • hachoir (for reading video metadata)
  • ttkbootstrap (for the GUI)
pip install pyexiv2 hachoir ttkbootstrap

Usage

  1. Launch ExifPlus: After installation, you can run ExifPlus directly from the command line (or from your Python script).

    python -m exifplus
    

    This will open the ExifPlus GUI, where you can load your files and begin editing metadata.

  2. Open (Local file / From URL) Click the Open button to load an image or video. When you click Open a small dialog appears letting you choose one of two options:

    • Local File — choose a single image or video file from your computer.
    • From URL — paste a public image/video URL and ExifPlus will download and open it for inspection.

    Supported formats

    • Images: .jpg, .jpeg, .png, .tiff, .heic
    • Videos: .mp4, .mov, .avi, .mkv

    Notes & troubleshooting

    • 403 / hotlinking: Some sites block programmatic downloads (hotlink protection or CDN rules). If a URL download is blocked ExifPlus will prompt you to open the image in your browser so you can save it manually.
    • No EXIF on hosted/resized images: Services like Blogger/Google often strip EXIF metadata when resizing or serving images. If a URL opens but shows no metadata, try using the original/original-size file you uploaded instead of a CDN/resized copy.
    • Windows users: In-place writing of metadata may be limited on Windows (some native libraries are unstable). Use the Export → JSON/CSV feature to save metadata, or run on Linux/macOS for full read/write support.
  3. View and Edit Metadata: Once the file is loaded, the metadata will be displayed in a table format with columns for the metadata Key and Value. You can:

    • Double-click a cell to edit its value.
    • Right-click to bring up a context menu with options like deleting the metadata row.
  4. Save Metadata: After editing metadata, click the "Save Metadata" button to save your changes. The metadata will be saved back to the file.

  5. Delete Metadata Row: To delete a specific metadata entry, right-click on a row and select "Delete Row". A confirmation dialog will appear to ensure you want to proceed with the deletion.

  6. Generate Report (HTML) Click the Generate Report button to create a clean, professional HTML metadata report, ideal for:

    • Bugcrowd submissions
    • HackerOne reports
    • Security audits
    • Forensic analysis
    • Documentation

    The generated HTML report includes:

    • Side-by-side image preview and metadata table
    • Clean markup that can be viewed in any browser
    • Easily attachable as a file or screenshot
    • Automatically extracted EXIF, IPTC, XMP, and video/image metadata

    This feature makes it extremely easy to share metadata findings professionally.

  7. About Window: Click on the "About" button to view information about the tool and the author.

Troubleshooting

  • Error: pyexiv2 is missing or fails to load: Make sure you've installed the necessary dependencies. You may need to install system packages for pyexiv2 to work properly on some systems (Linux or macOS). Refer to the pyexiv2 documentation for installation instructions.

  • Error: Invalid metadata key: When trying to modify metadata, ensure that the key you're trying to modify exists in the original file. You can view all the available keys in the table after loading a file.

📦 Installation

🔹 Recommended (Pipx)

If you intend to run ExifPlus as an application:

pipx install exifplus

Then run it:

exifplus

🔹 Using pip (Virtual Environment)

python3 -m venv venv
source venv/bin/activate
pip install exifplus

Run:

exifplus

⚠️ Debian/Ubuntu/Parrot/Kali Users

These systems use PEP 668 and block global installs. If you try:

pip install exifplus

You may see:

error: externally-managed-environment

To fix, use either:

pipx install exifplus

or:

python3 -m venv venv
source venv/bin/activate
pip install exifplus

🔧 Optional (Not required but allowed)

If you really want to install system-wide:

pip install exifplus --break-system-packages

Not recommended.


🚀 Running

After installation:

exifplus

or

python -m exifplus

Screenshots

ExifPlus Screenshot ExifPlus Screenshot ExifPlus Screenshot ExifPlus Screenshot ExifPlus Screenshot ExifPlus Screenshot ExifPlus Screenshot ExifPlus Screenshot


Contributing

Contributions to ExifPlus are welcome! If you'd like to report a bug, suggest a feature, or submit a pull request, feel free to fork the project and submit changes.

  1. Fork the repository.
  2. Clone your fork to your local machine.
  3. Make your changes (bug fixes, features, improvements).
  4. Submit a pull request with a clear description of your changes.

👨‍💻 Author

Developed by:

👉 Mohammed Zahid Wadiwale

Support development by buying:

  • Hosting
  • Domains
  • Websites
  • Cybersecurity services
  • Courses

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

exifplus-1.2.1.tar.gz (16.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

exifplus-1.2.1-py3-none-any.whl (13.3 kB view details)

Uploaded Python 3

File details

Details for the file exifplus-1.2.1.tar.gz.

File metadata

  • Download URL: exifplus-1.2.1.tar.gz
  • Upload date:
  • Size: 16.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for exifplus-1.2.1.tar.gz
Algorithm Hash digest
SHA256 3ba63ed7982554b073048f60dde6ebef4b419d622e8453065737340fdb28760e
MD5 54ee2f4f0bb69945342673a56e0c614b
BLAKE2b-256 dbdbe0ac15f9079b06943f2c381bcef02487d5aff4e8fb67b6746613bdeceefc

See more details on using hashes here.

File details

Details for the file exifplus-1.2.1-py3-none-any.whl.

File metadata

  • Download URL: exifplus-1.2.1-py3-none-any.whl
  • Upload date:
  • Size: 13.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for exifplus-1.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 bdc19b6173e7ed02ef46e9d21f6d99cb0a4ae21d614b63847e1b2e121a17a826
MD5 d964bcb3506480bccf03ae2d1f58dfcd
BLAKE2b-256 ee15c0a00f01fea834cd9fd8bd9f8e195419c5f789344f58c6d6a053a75bed02

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page