
特定のパターンに一致する行を修正するためにawkをどのように使用できますか?ただし、次の行が他のパターンと一致しない場合にのみ適用されますか?
次のスニペットを例に挙げます。
....
pattern1 100 200 300
pattern1 300 400 400
pattern2 300 900 700
pattern1 200 500 900
...
pattern1
含まれている行の後に続く2行目を除いて、含まれているすべての行を変更したいと思いますpattern2
。
これは次のようになります。この問題、しかし正反対です。
答え1
次のことを試してください
/pattern2/ { print intact ; print $0 ; next ;}
! /pattern2/ { print new ;}
{ intact=$0 ; $1="p1" ; new=$0 ; }
空の行
明らかにする
p1 100 200 300
pattern1 300 400 400
pattern2 300 900 700
p1 300 400 400
答え2
これが私が必要とするものです:
/pattern1/ {
if (candidate) {
print "modify:", candidate
}
candidate=$0
next
}
/pattern2/ {
if (candidate) {
print candidate
candidate=0
}
}
{
if (candidate) {
print "modify:", candidate
candidate=0
}
print $0
}
答え3
sed -e '
/pattern1/!b
$q; N
/\npattern2/!s/^/MODIFIED:/
P;D
' yourfile
perl -0777pe 's/(?=pattern1.*$)(?!pattern2)/MODIFIED:/gm' yourfile