在找到的字符串之前和之后删除Bash sed

时间:2018-03-11 16:15:37

标签: bash sed

我目前有以下代码:

sed -i "/# My Comment Text/,+2d" /etc/crontab

这会删除此行' #Mir Comment Text'之后的2行,但我还希望它删除此找到的字符串上方的1行。如何在我的1衬里sed命令中解决这个问题?

2 个答案:

答案 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