#dataset #net-cdf #variables #read-write #dimension #attributes #reading

netcdf3

A pure Rust library for reading and writing NetCDF-3 files

7 unstable releases

0.5.2 Feb 14, 2022
0.5.1 Dec 23, 2020
0.4.0 May 27, 2020
0.3.1 May 22, 2020
0.1.0 Apr 28, 2020

#1149 in Encoding

Download history 79/week @ 2024-11-16 79/week @ 2024-11-23 82/week @ 2024-11-30 111/week @ 2024-12-07 41/week @ 2024-12-14 9/week @ 2024-12-21 21/week @ 2024-12-28 16/week @ 2025-01-04 77/week @ 2025-01-11 160/week @ 2025-01-18 46/week @ 2025-01-25 92/week @ 2025-02-01 56/week @ 2025-02-08 52/week @ 2025-02-15 66/week @ 2025-02-22 42/week @ 2025-03-01

265 downloads per month
Used in mantaray

MIT/Apache

565KB
8K SLoC

netcdf3

Crates.io Crates.io Version Documentation Build Status codecov Minimum rustc version

Description

A pure Rust library for reading and writing NetCDF-3 files.

Technical features

  • Define a NetCDF-3 data set :
    • Create, get, rename, and remove global attributes.
    • Create, get, rename, and remove dimensions.
    • Create, get, rename, and remove variables.
    • Create, get, rename, and remove variable attributes.
  • Read a NetCDF-3 file :
    • Read all data of a variable.
    • Read all data of a record (a part of a variable defined on one NetCDF-3 record).
    • Read a slice of data.
    • Read a variable's data into a N-dimensional array (using the crate ndarray).
  • Write a NetCDF-3 file :
    • Write all data of a variable.
    • Write all data of a record (a part of a variable defined on one NetCDF-3 record).
    • Write a slice of data.
    • Write a variable's data from a N-dimensional array (using the crate ndarray).

Notes

  • Validations are done by comparing files produced by this crate and files produced by the Python library netCDF4(see the Python script pyscripts/create_test_nc3_files.py and the Rust test file tests/tests_write_nc3_files.rs).
  • If the number of records numrecs is greater than std::i32::MAX then this value is considered as indeterminate and the actually written value is numrecs = 2^32 - 1(see the File Format Specifications).
  • If the chunk size of a given variable vsize is greater the std::i32::MAX then its value is considered as indeterminate and the actually written value is vsize = 2^32 - 1 (see the File Format Specifications).

Known limitations

  • Cannot read/write a subset of a variable data yet.
  • Cannot rewrite a NetCDF-3 file.

Examples

Various examples are available here.

Dependencies

~1MB
~20K SLoC