Source code for pyart.util.datetime_utils

"""
Functions for converting date and time between various forms.

"""

try:
    from cftime import date2num, num2date
except ImportError:
    from netCDF4 import date2num, num2date

EPOCH_UNITS = "seconds since 1970-01-01T00:00:00Z"


[docs]def datetime_from_radar(radar, epoch=False, **kwargs): """Return a datetime for the first ray in a Radar.""" if epoch: dtrad = num2date(radar.time["data"][0], radar.time["units"]) epnum = date2num(dtrad, EPOCH_UNITS) return num2date(epnum, EPOCH_UNITS, **kwargs) else: return num2date(radar.time["data"][0], radar.time["units"], **kwargs)
[docs]def datetimes_from_radar(radar, epoch=False, **kwargs): """Return an array of datetimes for the rays in a Radar.""" if epoch: dtrad = num2date(radar.time["data"][:], radar.time["units"]) epnum = date2num(dtrad, EPOCH_UNITS) return num2date(epnum, EPOCH_UNITS, **kwargs) else: return num2date(radar.time["data"][:], radar.time["units"], **kwargs)
[docs]def datetime_from_dataset(dataset, epoch=False, **kwargs): """Return a datetime for the first time in a netCDF Dataset.""" if epoch: dtdata = num2date(dataset.variables["time"][0], dataset.variables["time"].units) epnum = date2num(dtdata, EPOCH_UNITS) return num2date(epnum, EPOCH_UNITS, **kwargs) else: return num2date( dataset.variables["time"][0], dataset.variables["time"].units, **kwargs )
[docs]def datetimes_from_dataset(dataset, epoch=False, **kwargs): """Return an array of datetimes for the times in a netCDF Dataset.""" if epoch: dtdata = num2date(dataset.variables["time"][:], dataset.variables["time"].units) epnum = date2num(dtdata, EPOCH_UNITS) return num2date(epnum, EPOCH_UNITS, **kwargs) else: return num2date( dataset.variables["time"][:], dataset.variables["time"].units, **kwargs )
[docs]def datetime_from_grid(grid, epoch=False, **kwargs): """Return a datetime for the volume start in a Grid.""" if epoch: dtrad = num2date(grid.time["data"][0], grid.time["units"]) epnum = date2num(dtrad, EPOCH_UNITS) return num2date(epnum, EPOCH_UNITS, **kwargs) else: return num2date(grid.time["data"][0], grid.time["units"], **kwargs)