下面这几条是我自己在写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”
法二:变量的子串替换(推荐,直接简单)