我目前有以下代码:
sed -i "/# My Comment Text/,+2d" /etc/crontab
这会删除此行' #Mir Comment Text'之后的2行,但我还希望它删除此找到的字符串上方的1行。如何在我的1衬里sed命令中解决这个问题?
答案 0 :(得分:1)
这是2个sed命令来完成这个技巧。如果您的输入文件看起来像
1
2
3
4 # My Comment Text
5
6
7
8
我们要删除第3,4,5,6行。
$ sed '/# My Comment Text/ {h;N;N;g}' file | tac | sed '/# My Comment Text/,+1d' | tac
1
2
7
8
第一个sed命令删除匹配行后的2行,而不删除匹配的行 然后我们反转文件并删除匹配的行和后面的行(这是普通文件中的前一行 重新反转输入,我们已经完成了。
答案 1 :(得分:0)
这应该有效。我在mac上使用了gsed
来获取GNU sed。在Linux上,您应该能够使用普通的sed
。
$ seq 10 | sed 's/^5/5 # my comment text/' | gsed -e ':b;$!{N;1bb;};/# my comment text/,+2!P;D'
1
2
3
7
8
9
10