From 5c55606a8f2467c7429fd6435870df8eb4e9865c Mon Sep 17 00:00:00 2001 From: Chris Markiewicz Date: Tue, 10 Dec 2024 17:25:28 -0500 Subject: [PATCH] fix: Use removeprefix instead of lstrip or ternary operator --- fmriprep/cli/parser.py | 5 +---- fmriprep/reports/core.py | 8 ++++---- fmriprep/utils/bids.py | 2 +- 3 files changed, 6 insertions(+), 9 deletions(-) diff --git a/fmriprep/cli/parser.py b/fmriprep/cli/parser.py index 63b4cd9d4..635724cbb 100644 --- a/fmriprep/cli/parser.py +++ b/fmriprep/cli/parser.py @@ -105,9 +105,6 @@ def _to_gb(value): units = value[len(digits) :] or 'M' return int(digits) * scale[units[0]] - def _drop_sub(value): - return value[4:] if value.startswith('sub-') else value - def _process_value(value): import bids @@ -205,7 +202,7 @@ def _slice_time_ref(value, parser): '--participant_label', action='store', nargs='+', - type=_drop_sub, + type=lambda label: label.removeprefix('sub-'), help='A space delimited list of participant identifiers or a single ' 'identifier (the sub- prefix can be removed)', ) diff --git a/fmriprep/reports/core.py b/fmriprep/reports/core.py index 33fb92f7e..9544ea327 100644 --- a/fmriprep/reports/core.py +++ b/fmriprep/reports/core.py @@ -79,6 +79,7 @@ def generate_reports( errors = [] for subject_label in subject_list: + subject_label = subject_label.removeprefix('sub-') # The number of sessions is intentionally not based on session_list but # on the total number of sessions, because I want the final derivatives # folder to be the same whether sessions were run one at a time or all-together. @@ -95,7 +96,7 @@ def generate_reports( else: # Beyond a threshold, we separate the anatomical report from the functional. bootstrap_file = data.load('reports-spec-anat.yml') - html_report = f'sub-{subject_label.lstrip("sub-")}_anat.html' + html_report = f'sub-{subject_label}_anat.html' report_error = run_reports( output_dir, @@ -121,12 +122,11 @@ def generate_reports( subject=subject_label, **filters ) - # Drop ses- prefixes - session_list = [ses[4:] if ses.startswith('ses-') else ses for ses in session_list] + session_list = [ses.removeprefix('ses-') for ses in session_list] for session_label in session_list: bootstrap_file = data.load('reports-spec-func.yml') - html_report = f'sub-{subject_label.lstrip("sub-")}_ses-{session_label}_func.html' + html_report = f'sub-{subject_label}_ses-{session_label}_func.html' report_error = run_reports( output_dir, diff --git a/fmriprep/utils/bids.py b/fmriprep/utils/bids.py index 5ca78d91c..f700ed062 100644 --- a/fmriprep/utils/bids.py +++ b/fmriprep/utils/bids.py @@ -217,7 +217,7 @@ def validate_input_dir(exec_env, bids_dir, participant_label, need_T1w=True): # Limit validation only to data from requested participants if participant_label: all_subs = {s.name[4:] for s in bids_dir.glob('sub-*')} - selected_subs = {s[4:] if s.startswith('sub-') else s for s in participant_label} + selected_subs = {s.removeprefix('sub-') for s in participant_label} bad_labels = selected_subs.difference(all_subs) if bad_labels: error_msg = (