Regular Expressions 101

@regex101
Donate
Sponsor
Contact
Bug Reports & Feedback
Wiki
Whats new?

Save & Share

  • Save Regex
    ctrl+s
  • Update Regex
    ctrl+⇧+s

Flavor

  • PCRE2 (PHP >=7.3)
  • PCRE (PHP <7.3)
  • ECMAScript (JavaScript)
  • Python 2.7
  • Golang
  • Java 8

Function

  • Match
  • Substitution
  • List
  • Unit Tests
/
(?xsm) # free-spacing mode, DOTALL, multi-line (?=.*?blue) # if blue isn't there, fail without delay ###### Recursive Section ###### # This section aims to balance empty lines with digits, i.e. # emptyLine,emptyLine,emptyLine ... ~1~2~3 # The last digit block is captured to Group 2, e.g. ~3 (?= # lookahead ( # Group 1 (?: # skip one line that doesn't contain blue ^ # start of line (?:(?!blue)[^\r\n])* # zero or more chars not followed by blue (?:\r?\n) # newline ) (?:(?1)|[^~]+) # recurse Group 1 OR match all non-tilde chars (~\d+) # match a sequence of digits )? # End Group 1 ) # End lookahead. # Group 2, if set, now contains the number of lines skipped .*? # lazily match chars up to... blue # match blue .*? # lazily match chars up to... (?(2)\2) # if Group 2 is set, match Group 2 ~ # Match the next tilde \K # drop what was matched so far \d+ # match the next digits: this is the match
/
(?xsm)
match the remainder of the pattern with the following effective flags: xsm
x modifier: extended. Spaces and text after a # in the pattern are ignored
s modifier: single line. Dot matches newline characters
m modifier: multi line. Causes ^ and $ to match the begin/end of each line (not only begin/end of string)
Comment: free-spacing mode, DOTALL, multi-line
Positive Lookahead
(?=.*?blue)
Assert that the Regex below matches
.
matches any character
*? matches the previous token between zero and unlimited times, as few times as possible, expanding as needed (lazy)
blue matches the characters blue literally (case sensitive)
Comment: if blue isn't there, fail without delay
Comment: ##### Recursive Section ######
Comment: This section aims to balance empty lines with digits, i.e.
Comment: emptyLine,emptyLine,emptyLine ... ~1~2~3
Comment: The last digit block is captured to Group 2, e.g. ~3
Positive Lookahead
(?= # lookahead ( # Group 1 (?: # skip one line that doesn't contain blue ^ # start of line (?:(?!blue)[^\r\n])* # zero or more chars not followed by blue (?:\r?\n) # newline ) (?:(?1)|[^~]+) # recurse Group 1 OR match all non-tilde chars (~\d+) # match a sequence of digits )? # End Group 1 )
Assert that the Regex below matches
Comment: End lookahead.
Comment: Group 2, if set, now contains the number of lines skipped
.
matches any character
Comment: lazily match chars up to...
Comment: match blue
.
matches any character
Comment: lazily match chars up to...
Conditional
(?(2)\2)
Comment: if Group 2 is set, match Group 2
Comment: Match the next tilde
\K resets the starting point of the reported match. Any previously consumed characters are no longer included in the final match
Comment: drop what was matched so far
\d
matches a digit (equivalent to [0-9])
Comment: match the next digits: this is the match
Your regular expression does not match the subject string.Try launching the debugger to find out why.

Regular Expression
No Match

/
/

Test String