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万+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章