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 e 3 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 g 3 h r 1 3 e g e y g e s e g g g g