import re
regex = re.compile(r"\Dshared\Dsections\D\d{3,5}[?](program_id|nav_info=&program_id)=6")
test_str = ("Past Strings: \n"
"\\Dshared\\Dsections\\D\\d{3,5}[?]nav_info=&{0,1}program_id=6\n\n"
"Pass:\n"
"/shared/sections/6032?nav_info=&program_id=6\n"
"/shared/sections/6027?program_id=6\n"
"/shared/sections/8990?program_id=6\n"
"/shared/sections/6115?nav_info=&program_id=6\n"
"/shared/sections/7318?program_id=6\n"
"/shared/sections/8996?program_id=6\n"
"/shared/sections/6324?nav_info=&program_id=6\n"
"/shared/sections/6332?program_id=6\n"
"/shared/sections/6333?program_id=6\n"
"/shared/sections/6334?program_id=6\n\n\n"
"Fail:\n"
"/shared/programs/6/lessons/1126/slide_shows\n"
"/shared/programs/6/lessons/964/slide_shows\n"
"/shared/programs/6/lessons/944/slide_shows\n"
"/shared/programs/6/lessons/963/slide_shows\n"
"/shared/programs/6/lessons/970/slide_shows\n"
"/shared/sections/7352?nav_info=&program_id=15\n"
"/shared/sections/8991?program_id=15\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