From ff8ff81636f65e84d3ebf20d82d6e01841563cfd Mon Sep 17 00:00:00 2001 From: Ken Kehoe Date: Fri, 26 Jan 2024 16:12:43 -0700 Subject: [PATCH 1/4] Ignoring statement for flake8 --- act/io/hysplit.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/act/io/hysplit.py b/act/io/hysplit.py index f0c410d0eb..5c0c2fd6aa 100644 --- a/act/io/hysplit.py +++ b/act/io/hysplit.py @@ -78,7 +78,7 @@ def read_hysplit(filename, base_year=2000): for variable in data[1:]: var_list.append(variable) input_df = pd.read_csv( - filename, sep='\s+', index_col=False, names=var_list, skiprows=12) + filename, sep='\s+', index_col=False, names=var_list, skiprows=12) # noqa W605 input_df['year'] = base_year + input_df['year'] input_df['time'] = pd.to_datetime(input_df[["year", "month", "day", "hour", "minute"]], format='%y%m%d%H%M') From 88536807a9e715d3f4d2610c28e8b19a3764729a Mon Sep 17 00:00:00 2001 From: Ken Kehoe Date: Fri, 26 Jan 2024 16:12:57 -0700 Subject: [PATCH 2/4] Ignoring statement for flake8 --- examples/plotting/plot_scatter.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/examples/plotting/plot_scatter.py b/examples/plotting/plot_scatter.py index dd9202f05d..698f47373f 100644 --- a/examples/plotting/plot_scatter.py +++ b/examples/plotting/plot_scatter.py @@ -31,7 +31,7 @@ 'ground_speed', m_field='ambient_temp', marker='x', - cbar_label='Ambient Temperature ($^\circ$C)' + cbar_label='Ambient Temperature ($^\circ$C)' # noqa W605 ) # Set the range of the field on the x-axis From d05cca6d1d987189c1450f8ff448d71770a52f5f Mon Sep 17 00:00:00 2001 From: Ken Kehoe Date: Fri, 26 Jan 2024 16:13:53 -0700 Subject: [PATCH 3/4] Adding keyword options to notify user when the unit conversion has a problem. --- act/utils/data_utils.py | 16 ++++++++++++++-- tests/utils/test_data_utils.py | 30 +++++++++++++++++++++++++++--- 2 files changed, 41 insertions(+), 5 deletions(-) diff --git a/act/utils/data_utils.py b/act/utils/data_utils.py index 5d499338dc..184aac92ed 100644 --- a/act/utils/data_utils.py +++ b/act/utils/data_utils.py @@ -35,7 +35,8 @@ def __init__(self, ds): self._ds = ds def change_units( - self, variables=None, desired_unit=None, skip_variables=None, skip_standard=True + self, variables=None, desired_unit=None, skip_variables=None, skip_standard=True, + verbose=False, raise_error=False ): """ Parameters @@ -51,6 +52,13 @@ def change_units( Flag indicating the QC variables that will not need changing are skipped. Makes the processing faster when processing all variables in dataset. + verbose : boolean + Option to print statement when an attempted conversion fails. Set to False + as default because many units strings are not udunits complient and when + trying to convert all varialbes of a type of units (eg temperature) the code + can print a lot of unecessary information. + raise_error : boolean + Raise an error if conversion is not successful. Returns ------- @@ -102,7 +110,11 @@ def change_units( pint.errors.UndefinedUnitError, np.core._exceptions.UFuncTypeError, ): - continue + if raise_error: + raise ValueError(f"Unable to convert '{var_name}' to units of '{desired_unit}'.") + elif verbose: + print(f"\n Unable to convert '{var_name}' to units of '{desired_unit}'. " + f"Skipping unit converstion for '{var_name}'.\n") return self._ds diff --git a/tests/utils/test_data_utils.py b/tests/utils/test_data_utils.py index bf10076164..03ceab41d3 100644 --- a/tests/utils/test_data_utils.py +++ b/tests/utils/test_data_utils.py @@ -4,6 +4,8 @@ import pytest import xarray as xr from numpy.testing import assert_almost_equal +from contextlib import redirect_stdout +from io import StringIO import act from act.utils.data_utils import DatastreamParserARM as DatastreamParser @@ -93,10 +95,13 @@ def test_convert_units(): data = act.utils.data_utils.convert_units(r_data, 'K', 'C') assert np.ceil(data[0]) == 12 - try: + # try: + # ds.utils.change_units() + # except ValueError as error: + # assert str(error) == "Need to provide 'desired_unit' keyword for .change_units() method" + + with np.testing.assert_raises(ValueError): ds.utils.change_units() - except ValueError as error: - assert str(error) == "Need to provide 'desired_unit' keyword for .change_units() method" desired_unit = 'degF' skip_vars = [ii for ii in ds.data_vars if ii.startswith('qc_')] @@ -138,6 +143,25 @@ def test_convert_units(): ds.close() del ds + # Test if exception or print statement is issued when an error occurs with units string + ds = act.io.arm.read_arm_netcdf(act.tests.sample_files.EXAMPLE_EBBR1) + with np.testing.assert_raises(ValueError): + ds.utils.change_units('home_signal_15', 'not_a_real_unit_string', raise_error=True) + + with np.testing.assert_raises(ValueError): + ds.utils.change_units('not_a_real_variable_name', 'degC', raise_error=True) + + f = StringIO() + var_name = 'home_signal_15' + unit = 'not_a_real_unit_string' + with redirect_stdout(f): + ds.utils.change_units('home_signal_15', 'not_a_real_unit_string', verbose=True) + s = f.getvalue() + assert s.strip() == f"Unable to convert '{var_name}' to units of '{unit}'. Skipping unit converstion for '{var_name}'." + + ds.close() + del ds + def test_ts_weighted_average(): ds = act.io.arm.read_arm_netcdf(act.tests.sample_files.EXAMPLE_MET_WILDCARD) From 837195bdefaba0fdee85144ed9680e45f22cebee Mon Sep 17 00:00:00 2001 From: Ken Kehoe Date: Mon, 29 Jan 2024 09:21:30 -0700 Subject: [PATCH 4/4] Removing old unused code. --- tests/utils/test_data_utils.py | 5 ----- 1 file changed, 5 deletions(-) diff --git a/tests/utils/test_data_utils.py b/tests/utils/test_data_utils.py index 03ceab41d3..ec1a0a920e 100644 --- a/tests/utils/test_data_utils.py +++ b/tests/utils/test_data_utils.py @@ -95,11 +95,6 @@ def test_convert_units(): data = act.utils.data_utils.convert_units(r_data, 'K', 'C') assert np.ceil(data[0]) == 12 - # try: - # ds.utils.change_units() - # except ValueError as error: - # assert str(error) == "Need to provide 'desired_unit' keyword for .change_units() method" - with np.testing.assert_raises(ValueError): ds.utils.change_units()