![]() |
Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java Node.js Objective-C PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Chilkat2-Python) Regular Expression with Multiple Matches and Capture GroupsSee more Regular Expressions ExamplesDemonstrates a regular expression with multiple matches and capture groups for each match.Note: Chilkat uses Note: This example requires Chilkat v11.1.0 or greater.
import sys import chilkat2 success = False pattern = "Name:\\s+(\\w+)\\s+(\\w+),\\s+Email:\\s+(\\S+)" sb = chilkat2.StringBuilder() crlf = True sb.AppendLine("Name: John Smith, Email: john.smith@example.com",crlf) sb.AppendLine("Name: Jack Johnson, Email: jack.johnson@example.com",crlf) sb.AppendLine("Name: Mary Adams, Email: mary.adams@example.com",crlf) print(sb.GetAsString()) # We have the following string: # Name: John Smith, Email: john.smith@example.com # Name: Jack Johnson, Email: jack.johnson@example.com # Name: Mary Adams, Email: mary.adams@example.com json = chilkat2.JsonObject() json.EmitCompact = False timeoutMs = 2000 numMatches = sb.RegexMatch(pattern,json,timeoutMs) if (numMatches < 0): # Probably an error in the regular expression. # Suggestion: Use AI to help create and/or diagnose regular expressions. print(sb.LastErrorText) sys.exit() # Examine the matches: print(json.Emit()) # This is the JSON with the match information. # See the JSON parsing code below to get the matched capture group values. # { # "match": [ # { # "group": [ # { # "cap": "Name: John Smith, Email: john.smith@example.com", # "idx": 0, # "len": 47 # }, # { # "cap": "John", # "idx": 6, # "len": 4 # }, # { # "cap": "Smith", # "idx": 11, # "len": 5 # }, # { # "cap": "john.smith@example.com", # "idx": 25, # "len": 22 # } # ] # }, # { # "group": [ # { # "cap": "Name: Jack Johnson, Email: jack.johnson@example.com", # "idx": 49, # "len": 51 # }, # { # "cap": "Jack", # "idx": 55, # "len": 4 # }, # { # "cap": "Johnson", # "idx": 60, # "len": 7 # }, # { # "cap": "jack.johnson@example.com", # "idx": 76, # "len": 24 # } # ] # }, # { # "group": [ # { # "cap": "Name: Mary Adams, Email: mary.adams@example.com", # "idx": 102, # "len": 47 # }, # { # "cap": "Mary", # "idx": 108, # "len": 4 # }, # { # "cap": "Adams", # "idx": 113, # "len": 5 # }, # { # "cap": "mary.adams@example.com", # "idx": 127, # "len": 22 # } # ] # } # ] # } # Important: Capture group 0 always contains the entire match — that is, the portion of the input string that matches the full regular expression. i = 0 matchCount = json.SizeOfArray("match") while i < matchCount : print("Match " + str(i + 1) + ":") json.I = i j = 0 numCaptureGroups = json.SizeOfArray("match[i].group") while j < numCaptureGroups : json.J = j cap = json.StringOf("match[i].group[j].cap") print(str(j) + ": " + cap) j = j + 1 i = i + 1 # Capture group 0 always contains the entire match — that is, the portion of the input string that matches the full regular expression. # Output # Match 1: # 0: Name: John Smith, Email: john.smith@example.com # 1: John # 2: Smith # 3: john.smith@example.com # Match 2: # 0: Name: Jack Johnson, Email: jack.johnson@example.com # 1: Jack # 2: Johnson # 3: jack.johnson@example.com # Match 3: # 0: Name: Mary Adams, Email: mary.adams@example.com # 1: Mary # 2: Adams # 3: mary.adams@example.co |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.