shell優化

下面這幾條是我自己在寫shell代碼的時候,比較喜歡的幾種寫法,拋磚引玉。

1) 檢查命令執行是否成功
第一種寫法,比較常見
echo abcdee | grep -q abcd

if [ $? -eq 0 ]; then
echo "Found"
else
echo "Not found"
fi

簡潔的寫法:
if echo abcdee | grep -q abc; then
echo "Found"
else
echo "Not found"
fi

2) 從1加到100之和

使用seq和awk實現
seq 100 |awk '{total+=$1} END {print total}'

簡潔的寫法:
seq -s “+” 100|bc

3) 查找文本中出現頻率最高的單詞
tr -cs "[[:alpha:]]" "\n" < file|sort|uniq -c|sort -nr

4)查找文本中某個單詞的個數
grep -o root /etc/passwd|wc –l
4

awk -v RS="root" 'END{print RS":"NR-1}' /etc/passwd
root:4

awk '{s+=gsub(/root/,"&")}END{print s}' /etc/passwd
4

5)過濾重複行
假設文件內容如下所示:
cat /tmp/file
1

1
2
3

常用的方法:
sort /tmp/file |uniq
1
2
3

簡單的寫法:
sort –u /tmp/file
awk '!a[$1]++{print}' /tmp/file

6)退而求其次的寫法
相信大家會有這種需求,當一個參數值沒有提供時,可以使用默認值。常見的寫法是:
arg=$1

if [ -z "$arg" ]; then
arg=0
fi

簡潔的寫法是這樣的:
arg=${1:-0}

7) 在一個目錄下有多個get.sh腳本文件,需要批量重命名爲put.sh
法一:用了兩個花括號,每個花括號代表了不同的含義
find . -type f -name "get.sh" -exec dirname {} \;|xargs -i mv {}/{get.sh,put.sh}

法二:簡單,不易出錯
find . -type f -name "get.sh" -exec dirname {} \;|xargs -i mv {}/get.sh {}/put.sh

8) 判斷變量是否爲數字的多種方法
法一:
egrep -wq '^[[:digit:]]+$' <<< "$num" || echo “not a number”

法二:變量的子串替換(推薦,直接簡單)

[ -n "${num//[0-9]/}" ] && echo “not a number” 

發佈了28 篇原創文章 · 獲贊 5 · 訪問量 3萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章