asp.net.ph

Skip Navigation Links

Grouping Constructs

Regular Expressions Language Elements


Grouping constructs allows you to capture groups of subexpressions and to increase the efficiency of regular expressions with noncapturing lookahead and lookbehind modifiers.

Grouping construct Definition
(     ) Captures the matched substring ( or noncapturing group; for more information, see the n option in Regular Expression Options ). Captures using ( ) are numbered automatically based on the order of the left parentheses, starting from one. The first capture, capture element number zero, is the text matched by the whole regular expression pattern.
( ?<name>    ) Captures the matched substring into a group name or number name. The string used for name must not contain any punctuation. You can use single quotes instead of angle brackets; for example, ( ?'name'    ).
( ?<name1-name2> ) Balancing group definition. Undefines the previously defined group name2 and stores in group name1 the interval between the previously defined name2 group and the current group. If no group name2 is defined, the match backtracks. Because deleting the last definition of name2 reveals the previous definition of name2, this construct allows the stack of captures for group name2 to be used as a counter for keeping track of nested constructs such as parentheses. In this construct name1 is optional. You can use single quotes instead of angle brackets; for example, ( ?'name1-name2' ).
( ?:    ) Noncapturing group.
( ?imnsx-imnsx:    ) Applies or disables the specified options within the subexpression. For example, ( ?i-s: ) turns on case insensitivity and disables single-line mode. For more information, see Regular Expression Options.
( ?=    ) Zero-width positive lookahead assertion. Continues match only if the subexpression matches at this position on the right. For example, \w+ ( ?=\d ) matches a word followed by a digit, without matching the digit. This construct does not backtrack.
( ?!    ) Zero-width negative lookahead assertion. Continues match only if the subexpression does not match at this position on the right. For example, \b ( ?!un ) \w+\b matches words that do not begin with un.
( ?<=    ) Zero-width positive lookbehind assertion. Continues match only if the subexpression matches at this position on the left. For example, ( ?<=19 ) 99 matches instances of 99 that follow 19. This construct does not backtrack
( ?<!    ) Zero-width negative lookbehind assertion. Continues match only if the subexpression does not match at the position on the left.
( ?>     ) Nonbacktracking subexpression ( also known as a greedy subexpression ). The subexpression is fully matched once, and then does not participate piecemeal in backtracking. ( That is, the subexpression matches only strings that would be matched by the subexpression alone. )

Named captures are numbered sequentially, based on the left-to-right order of the opening parentheses ( like unnamed captures ), but numbering of named captures starts after all unnamed captures have been counted. For instance, the pattern ( ( ?<One>abc ) /d+ ) ? ( ?<Two>xyz ) ( .* ) produces the following capturing groups by number and name. ( The first capture ( number 0 ) always refers to the entire pattern ).

0: {unnamed}
1: {unnamed}
2: {unnamed}
3: One
4: Two
See Also

ASP.NET Page Syntax



© 2025 Reynald Nuñez and asp.net.ph. All rights reserved.

If you have any question, comment or suggestion
about this site, please send us a note