1

我有包含一些行和一些数字的文件。我想删除特定字符串之后的所有行,让我们说字符串是“角度”。我想删除角度后的所有线,我可以使用 sed 命令执行此操作,如下所示:

sed -n '/angles/q;p' input file

我的问题是,我想删除角度之后的所有行但想保留最后四行?我怎样才能在 sed 中做到这一点?

4

5 回答 5

1

以下内容应该适合您:

tac inputfile | sed '5,/angles/d' | tac

说明:反转文件,保留前 4 行并删除所有内容,直到遇到所需的模式。反转结果。

于 2013-07-18T05:41:28.707 回答
1

这可能对您有用(GNU sed):

sed '1,/angles/b;:a;$!{N;s/\n/&/4;Ta;D}' file

打印出从第一行到遇到字符串的所有行angles。然后移动window四行并将它们打印在文件末尾。

于 2013-07-18T06:24:00.927 回答
0

In awk :

awk '{
     if(p!=1)print;
     else{a[NR]=$0}
     if($0~/angles/)p=1
     }
     END{
     for(i=NR-3;i<=NR;i++)print a[i]
     }' your_file

Tested below:

> cat temp
wbj
ergthet
gheheh
wergergkn   angles gerg
er
ergnmer
rgnerk
1
2
3
4
> awk '{if(p!=1)print;else{a[NR]=$0};if($0~/angles/)p=1}END{for(i=NR-3;i<=NR;i++)print a[i]}' temp
wbj
ergthet
gheheh
wergergkn   angles gerg
1
2
3
4
> 
于 2013-07-18T06:10:32.110 回答
0
awk -v size=$(wc -l < file) '
    /angles/       { skip=1 }
    NR >= (size-4) { skip=0 }
    !skip
' file
于 2013-07-18T12:54:22.143 回答
0

我将假设您要查找的字符串可能不止一次出现,并且您只想要第一个。如果这是真的,那么反转文件并不是最好的策略。

{ sed '/angles/q' file; tail -4 file; } > result
于 2013-07-19T00:56:12.877 回答