Source code for pyrfu.pyrf.read_cdf
#!/usr/bin/env python
# -*- coding: utf-8 -*-
# 3rd party imports
import numpy as np
import xarray as xr
from cdflib import cdfepoch, cdfread
from dateutil import parser
# Local imports
from .datetime2iso8601 import datetime2iso8601
__author__ = "Louis Richard"
__email__ = "louisr@irfu.se"
__copyright__ = "Copyright 2020-2023"
__license__ = "MIT"
__version__ = "2.4.2"
__status__ = "Prototype"
[docs]def read_cdf(path, tint):
r"""Reads CDF files.
Parameters
----------
path : str
String of the filename in .cdf containing the L2 data
tint : list
Time interval
Returns
-------
out_dict : dict
Hash table with fields contained in the .cdf file.
"""
tint = list(map(parser.parse, tint))
tint = list(map(datetime2iso8601, tint))
tint = list(map(cdfepoch.parse, tint))
out_dict = {}
with cdfread.CDF(path) as file:
keys_ = file.cdf_info()["zVariables"]
for k_ in keys_:
temp_ = file.varget(k_, starttime=tint[0], endtime=tint[1])
shape_ = temp_.shape
coords = [np.arange(lim_) for lim_ in shape_]
out_dict[k_.lower()] = xr.DataArray(temp_, coords=coords)
return out_dict