Shell 循環(huán)中實(shí)現(xiàn)展示進(jìn)度百分比的腳本方法
當(dāng)我需要處理一個(gè)幾萬(wàn)行的文件的時(shí)候,需要處理的時(shí)間是比較長(zhǎng)的。我一開始的想法是,沒處理一行,就輸出一個(gè) # 號(hào)。但是這樣還是會(huì)出現(xiàn)很多很多的 # 號(hào),即便是放在一行,也是非常不優(yōu)雅的。所以,我想實(shí)現(xiàn)一個(gè)展示進(jìn)度百分比的腳本。
實(shí)現(xiàn)思路
- 獲取文件的行數(shù)
- 用 i++ 實(shí)現(xiàn)每行處理的計(jì)數(shù)
- 當(dāng)前處理行數(shù)*100再除以文件行數(shù)+%得到我要輸出的百分比結(jié)果
- 我需要在一行展示,而不是一直追加或者每次都顯示一行
就是這些需求了。我們來(lái)逐漸實(shí)現(xiàn)。
獲取文件的行數(shù)
這個(gè)比較簡(jiǎn)單,用 wc -l $file 就能獲取到了。但是得到的結(jié)果我不是很滿意:
在結(jié)果的前面有幾個(gè)空格,我得把空格去掉,于是代碼就改成了
wc -l $file | sed 's/^[ \t]*//g'
這樣就去掉了開頭的空格,然后用空格分割,取第一個(gè)就可以了,cut來(lái)實(shí)現(xiàn)
wc -l $file | sed 's/^[ \t]*//g' | cut -d ' ' -f1
OK,通過(guò)幾個(gè)命令的組合,很容易的實(shí)現(xiàn)了獲取行數(shù)的數(shù)字。
echo 實(shí)現(xiàn)單行顯示
如上,就是將光標(biāo)提前四個(gè)位置,并錄入內(nèi)容。\b是提前一個(gè),輸入幾個(gè)就幾個(gè),如果已經(jīng)到了開頭了,就不能往前挪了,所以,多輸入幾個(gè)是沒問(wèn)題的。
最終實(shí)現(xiàn)代碼如下:
# 定義變量 i
i=1
# 獲取 3.log 這個(gè)文件的行數(shù),并把運(yùn)行結(jié)果賦予變量 l
l=$(wc -l 3.log | sed 's/^[ \t]*//g' | cut -d ' ' -f1)
# 每行遍歷循環(huán)
while read line; do
# 輸出百分比
echo -en "\b\b\b\b"`echo $i*100/$l | bc `'%'
# 計(jì)算 i++
((i++))
# 傳入 3.log 這個(gè)要處理的文件
done 3.log
# 完成時(shí)打個(gè)OK,因?yàn)樽址L(zhǎng)度不足以遮蓋原先的百分比,所以后面加了幾個(gè)空格
echo -e '\b\b\b\bOK '
實(shí)現(xiàn)效果如下

好,通過(guò)簡(jiǎn)單的幾行代碼,就實(shí)現(xiàn)了我想要的效果了。
以上腳本均在 mac 下測(cè)試通過(guò),在 Linux 下可能會(huì)有稍許不同。
如有疑問(wèn)請(qǐng)留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!
您可能感興趣的文章:- linux shell常用循環(huán)與判斷語(yǔ)句(for,while,until,if)使用方法
- Linux Shell在目錄下使用for循環(huán)結(jié)合if查找文件的巧用
- linux shell中實(shí)現(xiàn)循環(huán)日期的實(shí)例代碼
- 對(duì)Linux下shell編程之for循環(huán)的實(shí)例講解
- linux shell 中數(shù)組的定義和for循環(huán)遍歷的方法
- Linux shell 實(shí)現(xiàn)用for循環(huán)100次的方法
- Linux shell數(shù)組循環(huán)的實(shí)例詳解
- Linux shell編程中IO和條件及循環(huán)處理的細(xì)節(jié)問(wèn)題討論
- linux shell循環(huán):for、while、until用法詳解