in reply to Efficient method to replace middle lines only when no match
A line-by-line approach might actually be more efficient/maintainable, but if the file's already slurped, maybe something like this (needs Perl 5.10+ for \K but this could be worked around):
c:\@Work\Perl\monks>perl -wMstrict -le "use 5.010; ;; my $s = qq{yada\n} . qq{field1: valueA\n} . qq{some\n} . qq{lines\n} . qq{here\n} . qq{field3: valueC\n} . qq{blah blah\n} ; print qq{[[$s]]}; ;; my $replace = qq{field2: valueB\n}; ;; $s =~ s{ ^ field1: \s valueA \n \K (?! \Q$replace\E) .*? (?= field3: \s valueC \n) } {$replace}xmsg; print qq{[[$s]]}; " [[yada field1: valueA some lines here field3: valueC blah blah ]] [[yada field1: valueA field2: valueB field3: valueC blah blah ]]
Update 1: Changed (?! $replace) to (?! \Q$replace\E)
Update 2: I don't know if I just missed it or it was added after I began my reply, but the code at the bottom of the OP looks a lot like my post, and in fact is better since it takes care of variable value fields as mine does not. ?!?
|
|---|
| Replies are listed 'Best First'. | |
|---|---|
|
Re^2: Efficient method to replace middle lines only when no match
by Zu (Initiate) on Mar 20, 2014 at 06:54 UTC | |
by AnomalousMonk (Archbishop) on Mar 20, 2014 at 15:49 UTC |