PatternParser
imgtools.dicom.sort.parser
Parser module for extracting and validating placeholders from target patterns.
Summary
This module provides functionality to parse and validate sorting patterns with placeholders. Users can define custom regex patterns to extract keys from their sorting patterns.
Extended Summary
The PatternParser
class allows users to define patterns with placeholders
that can be replaced with actual values. The placeholders can be defined
using custom regex patterns, making the parser flexible for various use cases.
Examples:
Setup:
Example 1: Suppose you want to parse a target pattern like {Key1}-{Key2}
and replace the placeholders with values from a dictionary:
>>> pattern = '{Key1}-{Key2}'
>>> pattern_parser = re.compile(r'\{(\w+)\}')
>>> parser = PatternParser(
... pattern,
... pattern_parser,
... )
>>> (
... formatted_pattern,
... keys,
... ) = parser.parse()
>>> print(formatted_pattern)
'%(Key1)s-%(Key2)s'
>>> print(keys)
['Key1', 'Key2']
Now you can use the formatted pattern to replace the placeholders:
Example 2: Suppose you want to parse a target pattern like %<Key1> and {Key2}
and replace the placeholders with values from a dictionary:
>>> pattern = '%<Key1> and {Key2}'
>>> pattern_parser = re.compile(r'%<(\w+)>|\{(\w+)\}')
>>> parser = PatternParser(
... pattern,
... pattern_parser,
... )
>>> (
... formatted_pattern,
... keys,
... ) = parser.parse()
>>> print(formatted_pattern)
'%(Key1)s and %(Key2)s'
>>> print(keys)
['Key1', 'Key2']
Now you can use the formatted pattern to replace the placeholders:
Example 3: Suppose you want to parse a target pattern like /path/to/{Key1}/and/{Key2}
and replace the placeholders with values from a dictionary:
>>> pattern = '/path/to/{Key1}/and/{Key2}'
>>> pattern_parser = re.compile(r'\{(\w+)\}')
>>> parser = PatternParser(
... pattern,
... pattern_parser,
... )
>>> (
... formatted_pattern,
... keys,
... ) = parser.parse()
>>> print(formatted_pattern)
'/path/to/%(Key1)s/and/%(Key2)s'
>>> print(keys)
['Key1', 'Key2']
Now you can use the formatted pattern to replace the placeholders:
>>> resolved_string = formatted_pattern % key_values
>>> print(resolved_string)
'/path/to/folder1/and/folder2'
imgtools.dicom.sort.parser.PatternParser
PatternParser(pattern: str, pattern_parser: Pattern)
A helper class to parse, validate, and sanitize sorting patterns.
This class handles: - Pattern parsing and validation - Key extraction from patterns
Parameters:
Name | Type | Description | Default |
---|---|---|---|
|
str
|
The pattern string to parse. |
required |
|
Pattern
|
Custom regex pattern for parsing |
required |
Attributes:
Name | Type | Description |
---|---|---|
keys |
list of str
|
Extracted keys from the pattern. |
Examples:
>>> key_values = {
... 'Key1': 'Value1',
... 'Key2': 'Value2',
... }
>>> pattern = '{Key1}-{Key2}'
>>> pattern_parser = re.compile(r'\{(\w+)\}')
>>> parser = PatternParser(
... pattern,
... pattern_parser,
... )
>>> (
... formatted_pattern,
... keys,
... ) = parser.parse()
>>> print(formatted_pattern)
'%(Key1)s-%(Key2)s'
>>> print(keys)
['Key1', 'Key2']
>>> resolved_string = formatted_pattern % key_values
>>> print(resolved_string)
'Value1-Value2'
Methods:
Name | Description |
---|---|
parse |
Parse and validate the pattern. |
Source code in src/imgtools/dicom/sort/parser.py
parse
Parse and validate the pattern.
Returns:
Type | Description |
---|---|
Tuple[str, List[str]]
|
The formatted pattern string and a list of extracted keys. |