By default, a quantified subpattern is "greedy", that is, it will match as many times as possible (given a particular starting location) while still allowing the rest of the pattern to match. If you want it to match the minimum number of times possible, follow the quantifier with a "?" . Note that the meanings don't change, just the "greediness":$1 leaves space so that the other terms can match.
Update, consider:
A small update, I changed $a to $x in the above code. In Perl, $a and $b are special variables used for among other things in sort functions. Normal user code should not use these variables except in their strange special cases. So something like $x and $y is better. In the above code using $a wouldn't matter, but I changed it anyway to point out that this is a bad habit that can lead to problems in longer programs. Just something to watch out for if you code in other languages that don't have special meanings for a or b.my $x = "This is Perl"; $x =~/^((.+)(e|r)(.*))$/; print "1={$1} 2={$2} 3={$3} 4={$4}\n"; # 1={This is Perl} 2={This is Pe} 3={r} 4={l} my $x = "This is Perl, nice Perl"; $x =~/^((.+)(e|r)(.*))$/; print "1={$1} 2={$2} 3={$3} 4={$4}\n"; # 1={This is Perl, nice Perl} 2={This is Perl, nice Pe} 3={r} 4={l}
In reply to Re: Basic Regular expression
by Marshall
in thread Basic Regular expression
by skkeni04
| For: | Use: | ||
| & | & | ||
| < | < | ||
| > | > | ||
| [ | [ | ||
| ] | ] |