#exif #tags #tiff #metadata #gps

bin+lib rexif

RExif is a native Rust crate, written to extract EXIF data from JPEG and TIFF images

9 releases

0.7.3 May 14, 2021
0.5.3 May 9, 2021
0.5.1 Oct 31, 2020
0.5.0 Jan 27, 2020
0.3.1 Nov 9, 2015

#615 in Images

Download history 453/week @ 2023-12-19 356/week @ 2023-12-26 449/week @ 2024-01-02 655/week @ 2024-01-09 1420/week @ 2024-01-16 1490/week @ 2024-01-23 2422/week @ 2024-01-30 1195/week @ 2024-02-06 846/week @ 2024-02-13 690/week @ 2024-02-20 744/week @ 2024-02-27 614/week @ 2024-03-05 687/week @ 2024-03-12 668/week @ 2024-03-19 494/week @ 2024-03-26 633/week @ 2024-04-02

2,584 downloads per month
Used in 4 crates

MIT license

105KB
2.5K SLoC

rexif

RExif is a native Rust crate, written to extract EXIF data from JPEG and TIFF images.

The crate also contains a sample binary called 'rexiftool' that accepts files as arguments and prints the EXIF data. It gives a rough idea on how to use the crate.

I am still filling in the implementation of most EXIF tags. Merge requests, comments and criticisms about coding style, information about uncovered EXIF tags, sample images that are not parsed correctly -- in short, any sort of feedback is welcome!

Requirements

  • Latest stable Rust version (1.39 currently)

Example

match rexif::parse_file(&file_name) {
    Ok(exif) => {
        println!("{} {} exif entries: {}", file_name,
            exif.mime, exif.entries.len());

        for entry in &exif.entries {
            println!("    {}: {}",
                    entry.tag_readable,
                    entry.value_more_readable);
        }
    },
    Err(e) => {
        print!("Error in {}: {} {}", &file_name,
            Error::description(&e), e.extra).unwrap();
    }
}

The included tool refixtool accepts image file names as command-line parameters and prints EXIF data for them. The src/main.rs file is a good starting point to learn how to use the crate, then take a look into the ExifEntry struct.

Dependencies

~470KB