2 releases

0.1.1 Oct 21, 2024
0.1.0 Feb 15, 2024

#2064 in Parser implementations

Download history 206/week @ 2024-10-01 153/week @ 2024-10-08 216/week @ 2024-10-15 184/week @ 2024-10-22 44/week @ 2024-10-29 138/week @ 2024-11-05 35/week @ 2024-11-12 77/week @ 2024-11-19 1/week @ 2024-11-26 30/week @ 2024-12-03 78/week @ 2024-12-10 16/week @ 2024-12-17 3/week @ 2024-12-24 55/week @ 2024-12-31 101/week @ 2025-01-07 242/week @ 2025-01-14

407 downloads per month
Used in datavzrd

MIT license

17KB
308 lines

GitHub Workflow Status codecov

readervzrd

Readervzrd is a Rust library that provides utilities for reading tabular data from files without worrying if they are formatted as CSV or JSON. It offers flexible functionality to extract headers and iterate over records, supporting different file formats and structures.

Features

  • Supports uniform reading of data from CSV and JSON files.
  • Extracts headers from files.
  • Iterate over records
  • Handling of nested JSON structures

Installation

To use readervzrd in your Rust project, add it as a dependency in your Cargo.toml file:

[dependencies]
readervzrd = "0.1.0"

Usage

use readervzrd::{FileReader, FileError};

fn main() -> Result<(), FileError> {
    // Create a FileReader for a CSV file with ',' delimiter
    let mut reader = FileReader::new("data.csv", Some(','))?;

    // Create another FileReader for a JSON file
    let mut another_reader = FileReader::new("data.json", None)?;

    // Get headers from the file
    let headers = reader.headers()?;
    println!("Headers: {:?}", headers);

    // Iterate over records and process them
    for record in reader.records()? {
        println!("Record: {:?}", record);
    }

    Ok(())
}

Contributing

Contributions are welcome! If you find any issues or have suggestions for improvements, please open an issue or create a pull request on GitHub.

License

This project is licensed under the MIT License - see the LICENSE file for details.

Dependencies

~1.6–2.5MB
~40K SLoC