linux系統中將每行特定數目字元後的字元替換為指定字元
阿新 • • 發佈:2021-12-14
1、測試資料如下, 實現將每行的第3個e及其以後的e替換為g
root@PC1:/home/test/test# cat a.txt e r e y e u e e e g e 3 h r 1 3 e g e y e e s e e e e e
3、
root@PC1:/home/test/test# max=$(awk -F "e" '{print NF - 1}' a.txt | sort -rn | head -n 1) ## 統計每行用的e的最大數目 root@PC1:/home/test/test# echo $max 6
或者:
root@PC1:/home/test/test# max=$(awk -v FS="e" '{print NF - 1}' a.txt | sort -rn | head -n 1) root@PC1:/home/test/test# echo $max 6
或者:
root@PC1:/home/test/test# max=`awk '{print gsub(/e/,"$")}' a.txt | sort -rn | head -n 1` ## 利用awk統計每行特定字元出現的次數 root@PC1:/home/test/test# echo $max 6
4、利用迴圈將每行第3個及以後的e全部替換為g
root@PC1:/home/test/test# cat a.txt e r e y e u e e e g e3 h r 1 3 e g e y e e s e e e e e root@PC1:/home/test/test# cp a.txt a.txt_bak ## 要在原始檔中修改,防止以外,先備份檔案 root@PC1:/home/test/test# ls a.txt a.txt_bak root@PC1:/home/test/test# echo $max 6 root@PC1:/home/test/test# for i in `seq $max`; do sed -i 's/e/g/3' a.txt; done ## 利用迴圈替換 3 表示對第3個e進行替換 root@PC1:/home/test/test# cat a.txt ## 每行第3及以後的e全部替換為g e r e y g u g e e g g3 h r 1 3 e g e y g e s e g g g g