From 7b3b994cbe38df73a4149c4463b5f283ad297218 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jakob=20Gr=C3=B8hn?= Date: Fri, 18 Nov 2022 11:41:07 +0100 Subject: [PATCH] fix: bettee valueerror message formatting --- .../timeseriesflattener/feature_spec_objects.py | 17 +++++++++++------ 1 file changed, 11 insertions(+), 6 deletions(-) diff --git a/src/psycop_feature_generation/timeseriesflattener/feature_spec_objects.py b/src/psycop_feature_generation/timeseriesflattener/feature_spec_objects.py index 827356f8..8b1996ae 100644 --- a/src/psycop_feature_generation/timeseriesflattener/feature_spec_objects.py +++ b/src/psycop_feature_generation/timeseriesflattener/feature_spec_objects.py @@ -262,16 +262,21 @@ class MinGroupSpec(BaseModel): allowed_nan_value_prop: list[float] = [0.0] # If NaN is higher than this in the input dataframe during resolution, raise an error. - + def __init__(self, **data): super().__init__(**data) - + # Check that all passed loaders are valid - invalid_loaders = list(set(self.values_loader) - set(data_loaders.get_all())) + invalid_loaders = list( + set(self.values_loader) - set(data_loaders.get_all().keys()) + ) if len(invalid_loaders) != 0: - raise ValueError(f"""Invalid loader(s) specified. Following loaders were not found in the data_loaders registry: - {' '.join(str(loader) for loader in invalid_loaders)} - Available loaders:{' '.join(str(loader) for loader in data_loaders.get_all())}""") + nl = "\n" # New line variable as f-string can't handle backslashes + raise ValueError( + f"""Invalid loader(s) specified.{nl}{nl}Following loaders were not found in the data_loaders registry:""" + f"""{nl}{nl.join(str(loader) for loader in invalid_loaders)}{nl}{nl}""" + f"""Available loaders:{nl}{nl.join(str(loader) for loader in data_loaders.get_all().keys())}""" + ) if self.output_col_name_override: input_col_name = (