Domanda

I know that

sed '/match/ d' file

deletes all lines with matches, and

sed '1,3 s/match//g' file

deletes all matches in the first 3 lines.

But how do I delete all lines with matches in first 3 lines?

If possible, give a solution with only one sed call (no piping).

È stato utile?

Soluzione

You could combine the two:

sed '1,3{/match/d;}' file

This would delete lines containing match in the specified address range, i.e. in lines 1-3 in the example above.

Altri suggerimenti

If you like to test awk, it would be:

awk '/match/ && NR<=3 {next} 1' file
awk -v string="foo" 'NR<=3 && index($0,string) {next} 1' file
Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a StackOverflow
scroll top