Read Exif metadata from tiff and jpeg files.
Easy to use Python module to extract Exif metadata from tiff and jpeg files.
Originally written by Gene Cash & Thierry Bousch.
The recommended process is to install the PyPI package, as it allows easily staying up to date:
$ pip install exifread
See the pip documentation for more info.
Download an archive from the project’s releases page.
Extract and enjoy.
EXIF.py is tested on the following Python versions:
$ EXIF.py image.jpg
Show command line options:
import exifread # Open image file for reading (binary mode) f = open(path_name, 'rb') # Return Exif tags tags = exifread.process_file(f)
Note: To use this library in your project as a Git submodule, you should:
from <submodule_folder> import exifread
Returned tags will be a dictionary mapping names of Exif tags to their values in the file named by path_name. You can process the tags as you wish. In particular, you can iterate through all the tags with:
for tag in tags.keys(): if tag not in ('JPEGThumbnail', 'TIFFThumbnail', 'Filename', 'EXIF MakerNote'): print "Key: %s, value %s" % (tag, tags[tag])
An if statement is used to avoid printing out a few of the tags that tend to be long or boring.
The tags dictionary will include keys for all of the usual Exif tags, and will also include keys for Makernotes used by some cameras, for which we have a good specification.
Note that the dictionary keys are the IFD name followed by the tag name. For example:
'EXIF DateTimeOriginal', 'Image Orientation', 'MakerNote FocusMode'
Tags are divided into these main categories:
- Image: information related to the main image (IFD0 of the Exif data).
- Thumbnail: information related to the thumbnail image, if present (IFD1 of the Exif data).
- EXIF: Exif information (sub-IFD).
- GPS: GPS information (sub-IFD).
- Interoperability: Interoperability information (sub-IFD).
- MakerNote: Manufacturer specific information. There are no official published references for these tags.
These options can be used both in command line mode and within a script.
Don’t process makernote tags, don’t extract the thumbnail image (if any).
Pass the -q or --quick command line arguments, or as:
tags = exifread.process_file(f, details=False)
Stop at Given Tag
To stop processing the file after a specified tag is retrieved.
Pass the -t TAG or --stop-tag TAG argument, or as:
tags = exifread.process_file(f, stop_tag='TAG')
where TAG is a valid tag name, ex 'DateTimeOriginal'.
The two above options are useful to speed up processing of large numbers of files.
Return an error on invalid tags instead of silently ignoring.
Pass the -s or --strict argument, or as:
tags = exifread.process_file(f, strict=True)
All contributions are welcome!
Bug reports, feature requests, bug fixes, documentation updates, sample images, etc … Nothing is too small or too big ;-)
Please be aware that this is a purely spare time project, so don’t be offended if it takes some time to answer.
Please start from the develop branch for any code or documentation contributions. You may even find the work has already been done…
Normally the master branch is only for stable, released code.
Sample images are very important, allowing for validating new features and limiting regressions. On every build, the library is run on all images.
The samples are kept in a separate repository for space and bandwidth concerns:
Release history Release notifications
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
|Filename, size & hash SHA256 hash help||File type||Python version||Upload date|
|ExifRead-2.1.0-py2-none-any.whl (34.5 kB) Copy SHA256 hash SHA256||Wheel||2.7|
|ExifRead-2.1.0.tar.gz (32.5 kB) Copy SHA256 hash SHA256||Source||None|