#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

#611 in Images

Download history 532/week @ 2023-12-14 355/week @ 2023-12-21 400/week @ 2023-12-28 571/week @ 2024-01-04 586/week @ 2024-01-11 1527/week @ 2024-01-18 2232/week @ 2024-01-25 2072/week @ 2024-02-01 891/week @ 2024-02-08 717/week @ 2024-02-15 722/week @ 2024-02-22 697/week @ 2024-02-29 668/week @ 2024-03-07 586/week @ 2024-03-14 702/week @ 2024-03-21 547/week @ 2024-03-28

2,580 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