Sample code for 30+ languages & platforms
Unicode C++

Regular Expression with Multiple Matches and Named Capture Groups

See more Regular Expressions Examples

Demonstrates regular expressions with named capture groups and multiple matches.

Chilkat Unicode C++ Downloads

Unicode C++
#include <CkStringBuilderW.h>
#include <CkJsonObjectW.h>

void ChilkatSample(void)
    {
    bool success = false;

    CkStringBuilderW sb;
    bool crlf = true;
    sb.AppendLine(L"Name: John Smith",crlf);
    sb.AppendLine(L"Name: Jack Johnson",crlf);
    sb.AppendLine(L"Name: Mary Adams",crlf);

    wprintf(L"%s\n",sb.getAsString());

    // We have the following string:
    // Name: John Smith
    // Name: Jack Johnson
    // Name: Mary Adams

    const wchar_t *pattern = L"Name:\\s+(?<first>\\w+)\\s+(?<last>\\w+)";
    CkJsonObjectW json;
    json.put_EmitCompact(false);

    int timeoutMs = 2000;
    int 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.
        wprintf(L"%s\n",sb.lastErrorText());
        return;
    }

    // Examine the matches:
    wprintf(L"%s\n",json.emit());

    // Here is the JSON showing the matches.
    // Important:  Capture group 0 always contains the entire match — that is, the portion of the input string that matches the full regular expression.

    // {
    //   "named": {
    //     "first": 1,
    //     "last": 2
    //   },
    //   "match": [
    //     {
    //       "group": [
    //         {
    //           "cap": "Name: John Smith",
    //           "idx": 0,
    //           "len": 16
    //         },
    //         {
    //           "cap": "John",
    //           "idx": 6,
    //           "len": 4
    //         },
    //         {
    //           "cap": "Smith",
    //           "idx": 11,
    //           "len": 5
    //         }
    //       ]
    //     },
    //     {
    //       "group": [
    //         {
    //           "cap": "Name: Jack Johnson",
    //           "idx": 18,
    //           "len": 18
    //         },
    //         {
    //           "cap": "Jack",
    //           "idx": 24,
    //           "len": 4
    //         },
    //         {
    //           "cap": "Johnson",
    //           "idx": 29,
    //           "len": 7
    //         }
    //       ]
    //     },
    //     {
    //       "group": [
    //         {
    //           "cap": "Name: Mary Adams",
    //           "idx": 38,
    //           "len": 16
    //         },
    //         {
    //           "cap": "Mary",
    //           "idx": 44,
    //           "len": 4
    //         },
    //         {
    //           "cap": "Adams",
    //           "idx": 49,
    //           "len": 5
    //         }
    //       ]
    //     }
    //   ]
    // }

    // The capture group index is obtained by looking up the name in the JSON result.
    // For example:

    int idx_first = json.IntOf(L"named.first");
    int idx_last = json.IntOf(L"named.last");

    int i = 0;
    int matchCount = json.SizeOfArray(L"match");
    while (i < matchCount) {
        wprintf(L"Match %d:\n",i + 1);
        json.put_I(i);

        json.put_J(idx_first);
        wprintf(L"first: %s\n",json.stringOf(L"match[i].group[j].cap"));

        json.put_J(idx_last);
        wprintf(L"first: %s\n",json.stringOf(L"match[i].group[j].cap"));

        wprintf(L"\n");
        i = i + 1;
    }

    // Output is: 

    // Match 1:
    // first: John
    // first: Smith
    // 
    // Match 2:
    // first: Jack
    // first: Johnson
    // 
    // Match 3:
    // first: Mary
    // first: Adams
    }