Documentation | Build Status |
---|---|
NetCDF support for the Julia programming language, there is a high-level and a medium-level interface for writing and reading netcdf files.
pkg> add NetCDF
First, load the library:
using NetCDF
The high-level interface is quite similar to the Matlab NetCDF interface, reading files is done by:
x = ncread("myfile.nc", "Radiation")
which will read the variable called "Radiation" from the file "myfile.nc". General information can be gained by using
ncinfo(filename)
which gives an overview of the dimensions, variables and attributes stored in the file.
filename = "myfile.nc"
varname = "var1"
attribs = Dict("units" => "mm/d",
"data_min" => 0.0,
"data_max" => 87.0)
Creating variables and files is done by using the nccreate command:
nccreate(filename, varname, "x1", collect(11:20), "t", 20, Dict("units"=>"s"), atts=attribs)
This will create the variable called var1 in the file myfile.nc. The attributes defined in the Dict attribs are written to the file and are associated with the newly created variable. The dimensions "x1" and "t" of the variable are called "x1" and "t" in this example. If the dimensions do not exist yet in the file, they will be created. The dimension "x1" will be of length 10 and have the values 11..20, and the dimension "t" will have length 20 and the attribute "units" with the value "s".
Now we can write data to the file:
d = rand(10, 20)
ncwrite(d, filename, varname)
The full documentation can be found here
An alternative interface for reading NetCDF files can be found here: https://github.com/Alexander-Barth/NCDatasets.jl
As of version 0.9 we provide an interface to DiskArrays.jl, which lets you treat NetCDF variables as Julia AbstractArrays. Special methods for accessing, reading slices and reductions and broadcasting are implemented, so that working with the arrays should be efficient.
So the following returns a lazy AbstractArray container referencing the data in the variable.
v = NetCDF.open(filename, varname)
This package was originally started and is mostly maintained by Fabian Gans (fgans@bgc-jena.mpg.de). The automatic C wrapper generator was contributed by Martijn Visser (https://github.com/visr). Many thanks to several people who contributed bug fixes and enhancements.