![]() |
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
(SQL Server) 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.
-- Important: See this note about string length limitations for strings returned by sp_OAMethod calls. -- CREATE PROCEDURE ChilkatSample AS BEGIN DECLARE @hr int -- Important: Do not use nvarchar(max). See the warning about using nvarchar(max). DECLARE @sTmp0 nvarchar(4000) DECLARE @success int SELECT @success = 0 DECLARE @pattern nvarchar(4000) SELECT @pattern = 'Name:\s+(\w+)\s+(\w+),\s+Email:\s+(\S+)' DECLARE @sb int EXEC @hr = sp_OACreate 'Chilkat.StringBuilder', @sb OUT IF @hr <> 0 BEGIN PRINT 'Failed to create ActiveX component' RETURN END DECLARE @crlf int SELECT @crlf = 1 EXEC sp_OAMethod @sb, 'AppendLine', @success OUT, 'Name: John Smith, Email: john.smith@example.com', @crlf EXEC sp_OAMethod @sb, 'AppendLine', @success OUT, 'Name: Jack Johnson, Email: jack.johnson@example.com', @crlf EXEC sp_OAMethod @sb, 'AppendLine', @success OUT, 'Name: Mary Adams, Email: mary.adams@example.com', @crlf EXEC sp_OAMethod @sb, 'GetAsString', @sTmp0 OUT PRINT @sTmp0 -- 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 DECLARE @json int EXEC @hr = sp_OACreate 'Chilkat.JsonObject', @json OUT EXEC sp_OASetProperty @json, 'EmitCompact', 0 DECLARE @timeoutMs int SELECT @timeoutMs = 2000 DECLARE @numMatches int EXEC sp_OAMethod @sb, 'RegexMatch', @numMatches OUT, @pattern, @json, @timeoutMs IF @numMatches < 0 BEGIN -- Probably an error in the regular expression. -- Suggestion: Use AI to help create and/or diagnose regular expressions. EXEC sp_OAGetProperty @sb, 'LastErrorText', @sTmp0 OUT PRINT @sTmp0 EXEC @hr = sp_OADestroy @sb EXEC @hr = sp_OADestroy @json RETURN END -- Examine the matches: EXEC sp_OAMethod @json, 'Emit', @sTmp0 OUT PRINT @sTmp0 -- 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. DECLARE @cap nvarchar(4000) DECLARE @i int SELECT @i = 0 DECLARE @matchCount int EXEC sp_OAMethod @json, 'SizeOfArray', @matchCount OUT, 'match' WHILE @i < @matchCount BEGIN PRINT 'Match ' + @i + 1 + ':' EXEC sp_OASetProperty @json, 'I', @i DECLARE @j int SELECT @j = 0 DECLARE @numCaptureGroups int EXEC sp_OAMethod @json, 'SizeOfArray', @numCaptureGroups OUT, 'match[i].group' WHILE @j < @numCaptureGroups BEGIN EXEC sp_OASetProperty @json, 'J', @j EXEC sp_OAMethod @json, 'StringOf', @cap OUT, 'match[i].group[j].cap' PRINT @j + ': ' + @cap SELECT @j = @j + 1 END SELECT @i = @i + 1 END -- 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 EXEC @hr = sp_OADestroy @sb EXEC @hr = sp_OADestroy @json END GO |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.