From 81ac3ef5b2f202058bdf0f57717bc78789236aaa Mon Sep 17 00:00:00 2001 From: wtclarke Date: Thu, 31 Oct 2024 14:37:55 +0000 Subject: [PATCH] move from package_resources to importlib.resources for python 3.12+ compat --- spec2nii/bruker.py | 57 ++++++++++++++++++++++++---------------------- 1 file changed, 30 insertions(+), 27 deletions(-) diff --git a/spec2nii/bruker.py b/spec2nii/bruker.py index 9bf2d0e..a3367f7 100644 --- a/spec2nii/bruker.py +++ b/spec2nii/bruker.py @@ -7,7 +7,7 @@ Copyright (C) 2021 Institute of Scientific Instruments of the CAS, v. v. i. """ import os -import pkg_resources +import importlib.resources as importlib_resources import warnings from datetime import datetime @@ -64,40 +64,43 @@ def yield_bruker(args): 2/ Directory - function yields data and properties and data of all datasets compliant to the queries """ - # get location of the spec2nii Bruker properties configuration file - bruker_properties_path = pkg_resources.resource_filename('spec2nii', 'bruker_properties.json') - bruker_fid_override_path = pkg_resources.resource_filename('spec2nii', 'bruker_fid_override.json') - # get a list of queries to filter datasets queries = _get_queries(args) - # case of Bruker dataset - if os.path.isfile(args.file): - d = Dataset( - args.file, - property_files=[bruker_fid_override_path, bruker_properties_path], - parameter_files=['method']) - try: - d.query(queries) - except FilterEvalFalse: - raise ValueError(f'Bruker dataset {d.path} is not suitable for conversion to mrs_nifti') - yield from _proc_dataset(d, args) - - # case of folder containing Bruker datasets - elif os.path.isdir(args.file): - - # process individual datasets - for dataset in Folder(args.file, dataset_state={ - "parameter_files": ['method'], - "property_files": [bruker_properties_path] - }).get_dataset_list_rec(): - with dataset as d: + # get location of the spec2nii Bruker properties configuration file + ref1 = importlib_resources.files('spec2nii') / 'bruker_properties.json' + ref2 = importlib_resources.files('spec2nii') / 'bruker_fid_override.json' + + with importlib_resources.as_file(ref1) as bruker_properties_path: + with importlib_resources.as_file(ref2) as bruker_fid_override_path: + + # case of Bruker dataset + if os.path.isfile(args.file): + d = Dataset( + args.file, + property_files=[bruker_fid_override_path, bruker_properties_path], + parameter_files=['method']) try: d.query(queries) except FilterEvalFalse: - continue + raise ValueError(f'Bruker dataset {d.path} is not suitable for conversion to mrs_nifti') yield from _proc_dataset(d, args) + # case of folder containing Bruker datasets + elif os.path.isdir(args.file): + + # process individual datasets + for dataset in Folder(args.file, dataset_state={ + "parameter_files": ['method'], + "property_files": [bruker_properties_path] + }).get_dataset_list_rec(): + with dataset as d: + try: + d.query(queries) + except FilterEvalFalse: + continue + yield from _proc_dataset(d, args) + def _get_queries(args): """