sed或awk處理文件最后一行的實現(xiàn)方法
更新時間:2013年02月04日 18:33:24 作者:
sed或awk處理文件最后一行,供大家學習參考
有如下的文本:
abcd 1234 fds
2011 550
1023 832er 1231
要求處理后如下所示:
abcd 1234 fds
2011 550
total1:1023 total2:832er 12end
判斷如果是文本最后一行則在第一列前面加total1:,第二列加total2:, 第三列后面減掉后面兩個字符并加end。
分別用sed與awk來實現(xiàn)。
sed:
復制代碼 代碼如下:
echo 'abcd 1234 fds
2011 550
1023 832er 1231' |sed -r '$s/([^ ]*)( )([^ ]*)( )(..).*$/total1:\1\2total:\3\4\5end/'
abcd 1234 fds
2011 550
total1:1023 total:832er 12end
awk:
復制代碼 代碼如下:
awk 'NR>1{print a}{a=$0}END{$1="total1:"$1;$2="total2:"$2;print gensub(/..$/,"end",$0)}' file
awk 'BEGIN{getline a}{print a;a=$0}END{$1="total1:"$1;$2="total2:"$2;$3=gensub(/..$/,"end",1,$3);print}'
awk '{if(!getline line){print "total1:"$1" total2:"$2" "gensub(/..$/,"end",1,$3)}else{print line?$0 RS line:$0}}'
相關文章
Shell腳本實現(xiàn)亂序排列文件內(nèi)容的多種方法(洗牌問題)
這篇文章主要介紹了Shell腳本實現(xiàn)亂序排列文件內(nèi)容的多種方法(洗牌問題),本文給出3個Shell腳本和一個Python腳本解決亂序排列文件內(nèi)容問題,需要的朋友可以參考下2015-01-01詳解Shell編程之if語句實戰(zhàn)(小結(jié))
本篇文章主要介紹了詳解Shell編程之if語句實戰(zhàn)(小結(jié)),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-02-02