![]() |
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
(Visual Basic 6.0) 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: This example requires Chilkat v11.1.0 or greater.
Dim success As Long success = 0 Dim pattern As String pattern = "Name:\s+(\w+)\s+(\w+),\s+Email:\s+(\S+)" Dim sb As New ChilkatStringBuilder Dim crlf As Long crlf = 1 success = sb.AppendLine("Name: John Smith, Email: john.smith@example.com",crlf) success = sb.AppendLine("Name: Jack Johnson, Email: jack.johnson@example.com",crlf) success = sb.AppendLine("Name: Mary Adams, Email: mary.adams@example.com",crlf) Debug.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 Dim json As New ChilkatJsonObject json.EmitCompact = 0 Dim timeoutMs As Long timeoutMs = 2000 Dim numMatches As Long numMatches = sb.RegexMatch(pattern,json,timeoutMs) If (numMatches < 0) Then ' Probably an error in the regular expression. ' Suggestion: Use AI to help create and/or diagnose regular expressions. Debug.Print sb.LastErrorText Exit Sub End If ' Examine the matches: Debug.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. Dim cap As String Dim i As Long i = 0 Dim matchCount As Long matchCount = json.SizeOfArray("match") Do While i < matchCount Debug.Print "Match " & (i + 1) & ":" json.I = i Dim j As Long j = 0 Dim numCaptureGroups As Long numCaptureGroups = json.SizeOfArray("match[i].group") Do While j < numCaptureGroups json.J = j cap = json.StringOf("match[i].group[j].cap") Debug.Print j & ": " & cap j = j + 1 Loop i = i + 1 Loop ' 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.