I have a file, that looks like this:
expression1
- expresson1.1
- expressoion1.2
expression2
-expression2.1
expression3
-expression3.1
-expression3.2
-expression3.3
What I want to do is, delete lines 1.2, 3.2 and 3.3, so only lines that do not start with a minus, and the next line remain.
So I tried writing a regex that matches every line starting with a minus where the previous one also started with a minus, and then delete them.
So far, no success. Any hints would be very appreciated.
Depending on your regex flavor there is probably a way to activate multiline mode. In this case,
^
and$
match line beginnings and endings in addition to the start and end of the whole string.This should match at least two consecutive lines starting with
-
. The first capture/subpattern contains all lines after the first one. So these matches would be what you want to delete.Of course, replace
\n
with the line ending appropriate for your system.You can use this regex:
Replacing the matches with:
You can see this regex in action with RegExr here.
P.S. tough problem, here lookarounds don't work because you don't have fixed length prefixes to match against, while lookbehind (and lookahead) require fixed length strings as pointed out here (near the end of the page).
if an awk solution would be accepted by you, check the one-liner below:
test