import re
regex = re.compile(r"^[ \t]*data_augmentation_options[\s\S]+(?=^[ \t]*data_augmentation_options)", flags=re.MULTILINE)
test_str = (" batch_size: 4\n"
" num_steps: 30\n"
" data_augmentation_options {\n"
" random_horizontal_flip {\n"
" keypoint_flip_permutation: 0\n"
" keypoint_flip_permutation: 2\n"
" keypoint_flip_permutation: 1\n"
" keypoint_flip_permutation: 4\n"
" keypoint_flip_permutation: 3\n"
" keypoint_flip_permutation: 6\n"
" keypoint_flip_permutation: 5\n"
" keypoint_flip_permutation: 8\n"
" keypoint_flip_permutation: 7\n"
" keypoint_flip_permutation: 10\n"
" keypoint_flip_permutation: 9\n"
" keypoint_flip_permutation: 12\n"
" keypoint_flip_permutation: 11\n"
" keypoint_flip_permutation: 14\n"
" keypoint_flip_permutation: 13\n"
" keypoint_flip_permutation: 16\n"
" keypoint_flip_permutation: 15\n"
" }\n"
" }\n\n"
" data_augmentation_options {\n"
" random_crop_image {\n"
" min_aspect_ratio: 0.5\n"
" max_aspect_ratio: 1.7\n"
" random_coef: 0.25\n"
" }\n"
" }")
matches = regex.finditer(test_str)
for match_num, match in enumerate(matches, start=1):
print(f"Match {match_num} was found at {match.start()}-{match.end()}: {match.group()}")
for group_num, group in enumerate(match.groups(), start=1):
print(f"Group {group_num} found at {match.start(group_num)}-{match.end(group_num)}: {group}")
Please keep in mind that these code samples are automatically generated and are not guaranteed to work. If you find any syntax errors, feel free to submit a bug report. For a full regex reference for Python, please visit: https://docs.python.org/3/library/re.html