awk用法之:文本替換
awk的sub/gsub函數(shù)用來替換字符串,其語法格式是:
sub(/regexp/, replacement, target)
注意第三個(gè)參數(shù)target,如果忽略則使用$0作為參數(shù),即整行文本。
- 例子1:替換單個(gè)串
只把每行的第一個(gè)AAAA替換為BBBB
awk '{ sub(/AAAA/,"BBBB"); print $0 }' t.txt
- 例子2:替換所有的串
把每一行的所有AAAA替換為BBBB
awk '{ gsub(/AAAA/,"BBBB"); print $0 }' t.txt
- 例子3:替換滿足條件的行的串
只在出現(xiàn)字符串CCCC的前提下,將行中所有AAAA替換為BBBB
awk '/CCCC/ { gsub(/AAAA/,"BBBB"); print $0; next }
{ print $0 }
' t.txt
- 例子4:替換多個(gè)可選串
不管是AAAA,還是CCCC,全部替換為BBBB
awk '{ gsub(/AAAA|aaaa/,"BBBB"); print $0 }' t.txt
- 例子5:全字匹配替換
全字匹配AAAA;即不匹配AAA,以及AAAAA,也就是說完整的四個(gè)字符串AAAA。
awk '{ sub(/\<AAAA\>/,"BBBB"); print $0 }' t.txt
- 例子6:規(guī)則表達(dá)式匹配
把所有以A開頭,不管后面連續(xù)包含幾個(gè)A的串替換成一個(gè)字符B。
awk '{ gsub(/^A*/,"B"); print $0 }' t.txt