19 releases

0.6.1 Nov 6, 2024
0.5.5 Oct 22, 2022
0.5.4 Mar 26, 2021
0.5.2 Aug 7, 2020
0.1.0 Dec 31, 2016

#13 in Images

Download history 79642/week @ 2024-08-07 72370/week @ 2024-08-14 68542/week @ 2024-08-21 57621/week @ 2024-08-28 66558/week @ 2024-09-04 58945/week @ 2024-09-11 60920/week @ 2024-09-18 64626/week @ 2024-09-25 65548/week @ 2024-10-02 51481/week @ 2024-10-09 35724/week @ 2024-10-16 21841/week @ 2024-10-23 22530/week @ 2024-10-30 20629/week @ 2024-11-06 23290/week @ 2024-11-13 22071/week @ 2024-11-20

92,549 downloads per month
Used in 120 crates (51 directly)

BSD-2-Clause

240KB
5K SLoC

Exif parsing library written in pure Rust

This is a pure-Rust library to parse Exif data. This library parses Exif attributes in a raw Exif data block. It can also read Exif data directly from some image formats.

Supported formats are:

  • TIFF and some RAW image formats based on it
  • JPEG
  • HEIF and coding-specific variations including HEIC and AVIF
  • PNG
  • WebP

Usage

Add a dependency entry to your Cargo.toml. Specify "kamadak-exif" if you use crates.io. The canonical name of this crate is "exif", but it is renamed on crates.io to avoid a naming conflict.

  [dependencies]
  kamadak-exif = "x.y.z"

Add the following to your crate root (before Rust 2018).

  extern crate exif;

Run "cargo doc" in the source directory to generate the API reference. It is also available online at https://docs.rs/kamadak-exif.

See examples directory for sample codes.

Dependencies

Rust 1.60 or later is required to build.

Standards

  • Exif Version 2.32
  • DCF Version 2.0 (Edition 2010)
  • TIFF Revision 6.0
  • ISO/IEC 14496-12:2015
  • ISO/IEC 23008-12:2017
  • PNG Specification, Version 1.2
  • Extensions to the PNG 1.2 Specification, version 1.5.0
  • WebP Container Specification, committed on 2018-04-20

Dependencies