#csv #data #file-io #ndarray #2d-array #read-write #homogeneous

ndarray-csv

Easily read and write homogeneous CSV data to and from 2D ndarrays

12 releases

Uses old Rust 2015

0.5.3 Oct 25, 2024
0.5.2 May 4, 2023
0.5.1 Apr 25, 2021
0.5.0 Jan 30, 2021
0.3.1 Oct 30, 2018

#112 in Graphics APIs

Download history 1138/week @ 2024-09-24 764/week @ 2024-10-01 569/week @ 2024-10-08 1035/week @ 2024-10-15 744/week @ 2024-10-22 708/week @ 2024-10-29 1097/week @ 2024-11-05 6485/week @ 2024-11-12 12391/week @ 2024-11-19 9808/week @ 2024-11-26 12289/week @ 2024-12-03 12782/week @ 2024-12-10 10989/week @ 2024-12-17 1928/week @ 2024-12-24 5517/week @ 2024-12-31 11298/week @ 2025-01-07

32,077 downloads per month
Used in 25 crates (11 directly)

MIT/Apache

14KB
246 lines

ndarray-csv

Easily read and write homogeneous CSV data to and from 2D ndarrays.

extern crate csv;
extern crate ndarray;
extern crate ndarray_csv;

use csv::{ReaderBuilder, WriterBuilder};
use ndarray::{array, Array2};
use ndarray_csv::{Array2Reader, Array2Writer};
use std::error::Error;
use std::fs::File;

fn main() -> Result<(), Box<dyn Error>> {
    // Our 2x3 test array
    let array = array![[1, 2, 3], [4, 5, 6]];

    // Write the array into the file.
    {
        let file = File::create("test.csv")?;
        let mut writer = WriterBuilder::new().has_headers(false).from_writer(file);
        writer.serialize_array2(&array)?;
    }

    // Read an array back from the file
    let file = File::open("test.csv")?;
    let mut reader = ReaderBuilder::new().has_headers(false).from_reader(file);
    let array_read: Array2<u64> = reader.deserialize_array2((2, 3))?;

    // Ensure that we got the original array back
    assert_eq!(array_read, array);
    Ok(())
}

This project uses cargo-make for builds; to build, run cargo make all.

To prevent denial-of-service attacks, do not read in untrusted CSV streams of unbounded length; this can be implemented with std::io::Read::take.

License: MIT/Apache-2.0

Dependencies

~3MB
~50K SLoC