From dcf3ca444a3f820f5f3ae3a55f975e40f1c41526 Mon Sep 17 00:00:00 2001 From: Birte Kristina Friesel Date: Tue, 9 Jul 2024 16:13:28 +0200 Subject: filter_aggregate_by_param: <> only work for non-None values --- lib/utils.py | 18 +++++++++++++----- 1 file changed, 13 insertions(+), 5 deletions(-) (limited to 'lib') diff --git a/lib/utils.py b/lib/utils.py index 426b701..1c639ca 100644 --- a/lib/utils.py +++ b/lib/utils.py @@ -560,22 +560,30 @@ def filter_aggregate_by_param(aggregate, parameters, parameter_filter): param_index = parameters.index(param_name) except ValueError: logger.error(f"Unknown parameter '{param_name}'") - return + continue param_value = soft_cast_int(param_value) names_to_remove = set() if condition == "<": - condf = lambda x: x[param_index] < param_value + condf = ( + lambda x: x[param_index] is not None and x[param_index] < param_value + ) elif condition == "≤": - condf = lambda x: x[param_index] <= param_value + condf = ( + lambda x: x[param_index] is not None and x[param_index] <= param_value + ) elif condition == "=": condf = lambda x: x[param_index] == param_value elif condition == "≠": condf = lambda x: x[param_index] != param_value elif condition == "≥": - condf = lambda x: x[param_index] >= param_value + condf = ( + lambda x: x[param_index] is not None and x[param_index] >= param_value + ) elif condition == ">": - condf = lambda x: x[param_index] > param_value + condf = ( + lambda x: x[param_index] is not None and x[param_index] > param_value + ) elif condition == "∈": param_values = tuple(map(soft_cast_int, param_value.split(","))) condf = lambda x: x[param_index] in param_values -- cgit v1.2.3