sed multiline删除模式

时间:2016-06-07 13:21:11

标签: bash sed

我想删除像

这样的模式的所有多行出现
  {START-TAG
  foo bar
  ID: 111
  foo bar
  END-TAG}

  {START-TAG
  foo bar
  ID: 222
  foo bar
  END-TAG}

  {START-TAG
  foo bar
  ID: 333
  foo bar
  END-TAG}

我想删除包含特定ID的START-TAG和END-TAG之间的所有部分。

所以要删除ID:222,只剩下这个:

  {START-TAG
  foo bar 2
  ID: 111
  foo bar 3
  END-TAG}


  {START-TAG
  foo bar 2
  ID: 333
  foo bar 3
  END-TAG}

我有一个应该删除的ID黑名单。

我假设一个非常简单的多行sed正则表达式脚本会这样做。有人可以帮忙吗?

它与问题sed multiline replace非常相似,但不一样。

1 个答案:

答案 0 :(得分:12)

您可以使用以下内容:

sed '/{START-TAG/{:a;N;/END-TAG}/!ba};/ID: 222/d' data.txt

故障:

/{START-TAG/ { # Match '{START-TAG'
:a             # Create label a
N              # Read next line into pattern space
/END-TAG}/!    # If not matching 'END-TAG}'...
           ba  # Then goto a
}              # End /{START-TAG/ block
/ID: 222/d     # If pattern space matched 'ID: 222' then delete it.