ExifTool by Phil Harvey

 ExifTool Version 5 is Here!  -- Read and Write Meta Information!

ExifTool versions 4.00 through 4.95 were an evolution of the writing abilities, but with the release of version 5 all of the major planned writing features have now been incorporated!

Download Version 5.55 - Aug. 24, 2005 (Version History)

ExifTool is a Perl module with an included command-line application for reading and writing meta information in image files. It reads EXIF, GPS, IPTC, XMP, GeoTIFF, ICC Profile and Photoshop IRB meta information from JPG, JP2, TIFF, GIF, PNG, MNG, JNG, MIFF, EPS, PS, AI, PDF, PSD, BMP, THM, CRW, CR2, MRW, NEF, PEF, ORF and DNG images. ExifTool also extracts information from the maker notes of many digital cameras by various manufacturers including Canon, Casio, FujiFilm, Kodak, Minolta/Konica-Minolta, Nikon, Olympus/Epson, Panasonic/Leica, Pentax/Asahi, Ricoh, Sanyo and Sigma/Foveon.

ExifTool writes EXIF, GPS, IPTC, XMP and MakerNotes meta information to JPEG, TIFF, GIF, THM, CRW, CR2, NEF, PEF and DNG images. When writing, ExifTool preserves the original file by adding "_original" to the file name. You should keep a copy of the original, or thoroughly validate the new file before erasing the original. Read here for some ramblings on the subject of writing meta information.

Drop me a note if you find ExifTool useful, or if you have any comments or suggestions. My e-mail address is in the README file. Thanks.

Features

Writer Limitations

System Requirements

Requires Perl 5.004 or later. No other libraries or software required.

Windows users: You can get a good, free Perl interpreter from activeperl.com.
Everyone else: Don't worry, you should already have Perl installed.

Running exiftool

The exiftool application provides a convenient command-line interface for the Image::ExifTool Perl module (both included in the distribution package). Once you have downloaded and extracted the ExifTool package, you can immediately run exiftool (even before it is built and installed) by typing "DIR/exiftool FILE", where DIR is the directory where exiftool was extracted, and FILE is the name of an image file.

Many command-line options are available to give control over the output formatting and to allow reading or writing of specific information. Run exiftool with no arguments for a description of exiftool, complete list of available options, and examples.

Note: Windows users should type "perl exiftool" instead of just "exiftool" to run exiftool. Alternately, you can rename exiftool to exiftool.pl then type "exiftool.pl" to run it.

Example Output

> exiftool -h -canon pics/113_1366.JPG
File Name113_1366.JPG
Camera Model NameCanon EOS DIGITAL REBEL
Shooting Date/Time2003:10:31 15:44:19
Shooting ModeProgram AE
Tv(Shutter Speed)1/60
Av(Aperture Value)5.6
Metering ModeEvaluative
Exposure Compensation0
ISO Speed100
Lens18.0 - 55.0mm
Focal Length55.0mm
Image Size2048x3072
QualityNormal
FlashOn
Flash TypeBuilt-In Flash
Flash Exposure Compensation0
Red Eye ReductionOff
Shutter Curtain Sync1st-curtain sync
White BalanceAuto
Focus ModeAI Focus AF
Contrast+1
Sharpness+1
Saturation+1
Color ToneNormal
File Size811KB
Image Number113-1366
Drive ModeContinuous shooting
Owner's NamePhil Harvey
Camera Body No.0560012345

Verbose Output

The verbose option (-v) prints additional information that is useful for debugging or when decoding new tags.

ExifTool Tag Names

Tag names are entered on the command line with a leading '-' in the order you want them displayed. Case is not significant. The tag name may be prefixed by a group name from family 0 or 1, separated by a colon, to specify a location for the information. A special tag name of 'All' may be used to represent all tags, or all tags in a specified group.
ie) "exiftool -filename -imagesize -exif:fnumber -xmp:all image.jpg"

A complete list of ExifTool Tag Names accompanies this documentation. As well, current lists of available tag names and writable tag names may be obtained using the exiftool -list and -listw options. But perhaps the easiest way to determine a tag name is to use the -S option to print the tag names instead of descriptions for all information in a file. It may also be helpful to use the -G option to display the group names, and the -H or -D option to print the numerical tag ID's for reference.

Notes:

  1. Tag names sometimes differ from their descriptions. Use the '-S' command-line option to see the actual tag names instead of the descriptions when extracting information.
  2. Values are only displayed for tags that exist in the specified file when extracting information (unless the -f option is used).

Shortcut Tags

Shortcuts tags represent one or more other tags, and are used like any other tag when extracting information.

ExifTool defines a few shortcut tags in the Image::ExifTool::Shortcuts module, and allows users to define their own shortcuts by adding a definition to the .ExifTool_config file in their home directory. Here is a simple example that defines two shortcuts:

%Image::ExifTool::Shortcuts::UserDefined = (
    MyShortcut => ['createdate','exposuretime','aperture'],
    MyAlias => 'FocalLengthIn35mmFormat',
);
In this example, MyShortcut is a shortcut for the CreateDate, ExposureTime and Aperture tags, and MyAlias is a shortcut for FocalLengthIn35mmFormat.

The current shortcuts may be listed with the -list option.

Groups

ExifTool classifies tags into groups in three different families. These groups are:
FamilyGroup Names
0 (General Location) APP12, Composite, EXIF, ExifTool, File, GPS, GeoTiff, ICC_Profile, IPTC, Jpeg2000, MIFF, MNG, MakerNotes, PNG, Photoshop, PostScript, PrintIM, XMP
1 (Specific Location) APP12, Canon, CanonCustom, CanonRaw, Casio, Composite, ExifIFD, ExifTool, File, FujiFilm, GPS, GeoTiff, GlobParamIFD, ICC-chrm, ICC-clrt, ICC-header, ICC-meas, ICC-view, ICC_Profile, IFD0, IFD1, IPTC, InteropIFD, Jpeg2000, Kodak, KodakBordersIFD, KodakEffectsIFD, MIFF, MNG, MakerUnknown, Minolta, Nikon, NikonPreview, Olympus, PNG, Panasonic, Pentax, Photoshop, PostScript, PrintIM, Ricoh, Sanyo, Sigma, Sony, SubIFD, XMP, XMP-aux, XMP-crs, XMP-dc, XMP-exif, XMP-iptcCore, XMP-pdf, XMP-photoshop, XMP-tiff, XMP-xmp, XMP-xmpBJ, XMP-xmpMM, XMP-xmpRights
2 (Category) Author, Camera, ExifTool, Image, Location, Other, Printing, Time, Unknown
The exiftool output can be organized based on these groups using the -g or -G option.

Writing Meta Information

ExifTool writes five different types of meta information:

1) EXIF   2) GPS   3) IPTC   4) XMP   5) MakerNotes
Many tag names are valid for more than one of these groups. If a specific group is not given then new information is added only to the highest priority group for which the tag name is valid (but the information is changed in all groups where the tag already existed). The priority of the groups is given by the list above. Information is added preferentially to the EXIF or GPS group (there are no common tag names between these two groups). If the tag isn't valid in either of these two groups, the information is added to the IPTC group, or finally the XMP group. The Makernotes group is special, see the note below.

Alternatively, information may be written to a specific group only, bypassing these priorities, by providing a group name for the tag. The section below gives the syntax rules for exiftool command-line arguments to do this. Any family 0 or 1 group name may be used when writing information, although not all groups are writable.

Note: Information in the MakerNotes may be edited, but not added or deleted. The reason for this is to avoid confusing manufacturer-specific software which may be very inflexible about the information it expects in the maker notes. The exception is the JpgFromRaw image, which may be added or deleted from Canon CRW files. This has been tested and doesn't cause problems for me with the Canon software or Photoshop, however it does confuse Capture One somewhat if this image is missing, so beware.

Argument Syntax for Writing Information

Tag values are writen rather than being extracted if the tag name ends with a '=' symbol. The '=' may be prefixed by '+', '-' or '<' to add a value, remove a value or set a value from file. The following table outlines the different write syntaxes:

SyntaxResult
-TAG=Deletes all occurrances of TAG
-all=Deletes all meta information!
-GROUP:TAG=Deletes TAG only in specified group
-GROUP:all=Deletes all information in specified group
-[GROUP:]TAG=VALUESets value of TAG (only in GROUP if specified)
-[GROUP:]TAG+=VALUEAdds value to a tag list (only valid for List type tags)
-[GROUP:]TAG-=VALUEDeletes TAG only if it has the specified value
-[GROUP:]TAG<=FILESets tag value from contents of specified file

Note that quotes are required around VALUE if it contains spaces, and around the whole argument if the '<=' syntax is used (to prevent shell redirection).

The "-TagsFromFile" Option

A special ExifTool option allows copying tags from one file to another. The command-line syntax for doing this is "-TagsFromFile SRCFILE". Any tags specifed after this option on the command line are extracted from source file and written to the destination file. If no tags are specified, then all writable tags are copied. This option is very simple, yet very powerful. Depending on the formats of the source and destination files, some of tags read may not be valid in the destination file, in which case they aren't written. No translation between similar tags with different names is done, although information may be transferred between same-named tags in different groups.

The Image::ExifTool Perl Library Module

The 'exiftool' script is essentially just a command-line interface to the Image::ExifTool Perl library module which is part of the ExifTool distribution. The Image::ExifTool module can be used in any Perl script to provide easy access to meta information in images. Here is an example a very simple script that uses Image::ExifTool to print out all recognized meta information in a file:
#!/usr/bin/perl -w
use Image::ExifTool 'ImageInfo';
my $file = shift or die "Please specify filename";
my $info = ImageInfo($file);
foreach (keys %$info) {
    print "$_ : $info->{$_}\n";
}
Note that some tag values may be returned as SCALAR references indicating binary data. The simple script above does not handle this case.

See the Image::ExifTool Documentation for more details.

Related Utilities

Additional Documentation/Help

Also, visit the ExifTool Forum at CPAN.

License

It's free, and you're free to use it however you want.

Boldly Go where No Man has Gone Before...

There is still much unknown information in the maker notes for many camera models. (To see this information, run exiftool with the -U option.) If you manage to figure out what any of it means, send me an e-mail and I'll update ExifTool to decode this information. Many thanks to all who have helped so far...

Acknowledgements

The following sources of information were very useful in helping to figure out the file formats And thanks to the following people for their help: