Beefy Boxes and Bandwidth Generously Provided by pair Networks
There's more than one way to do things
 
PerlMonks  

Re: Re: Re: look-behind regex

by Anonymous Monk
on Jul 25, 2002 at 02:20 UTC ( [id://185095]=note: print w/replies, xml ) Need Help??


in reply to Re: Re: look-behind regex
in thread look-behind regex

In this particular case there's possibly a faster method though:

s/^(?!(?>.*?toto.*?foo))(.*?)foo/${1}bar/s;

If toto or foo can be found in the near beginning, Abigail's pattern is a winner. This is, I guess, due to the overhead of the (?>) assertion. But the farther away toto or foo is the worse it gets for the step-by-step method (/(?:(?!foo).)*/), and the (?>) pattern gets faster. (This isn't just a theoretical win. Even though the overhead due to (?>), that pattern might very well win in a real-life situation.)

But if I shall look at the big picture for a while though; in this case I find it hard to believe that any pattern can beat the plain and simple

s/foo/bar/ unless /toto.*?foo/s;

Even silly constructions like

s/foo(?(?{index($`, 'toto') != -1})(?!))/bar/;

is faster than the more generic solutions.

Cheers,
-Anomo

Log In?
Username:
Password:

What's my password?
Create A New User
Domain Nodelet?
Node Status?
node history
Node Type: note [id://185095]
help
Chatterbox?
and the web crawler heard nothing...

How do I use this?Last hourOther CB clients
Other Users?
Others goofing around in the Monastery: (3)
As of 2024-04-19 17:25 GMT
Sections?
Information?
Find Nodes?
Leftovers?
    Voting Booth?

    No recent polls found