1)基本语法
if [ 条件判断式 ];then
程序
fi
或者
if [ 条件判断式 ]
then
程序
fi
大于18,命令行输出OK
[root@hadoop ~]# a=25
[root@hadoop ~]# if [ $a -gt 18 ];then echo OK; fi
OK
[root@hadoop ~]# a=15
[root@hadoop ~]# if [ $a -gt 18 ]; then echo OK; fi
或者
[root@hadoop scripts]# a=25
[root@hadoop scripts]# if [ $a -gt 18 ] && [ $a -lt 35 ];then echo OK;fi
OK
判断是否张三,是输出张三
[root@hadoop scripts]# vim if_test.sh
#!/bin/bash
if [ "$1"x = "zhangsan"x ] #等号左右加x,避免输入空值报错
then
echo "zhangsan"
fi
[root@hadoop scripts]# . if_test.sh zhangsan
zhangsan
[root@hadoop scripts]# . if_test.sh
[root@hadoop scripts]# . if_test.sh lisi
逻辑与-a,逻辑或-o
[root@hadoop scripts]# a=36
[root@hadoop scripts]# if [ $a -gt 18 ] && [ $a -lt 35 ]; then echo OK; fi
[root@hadoop scripts]# if [ $a -gt 18 && $a -lt 35 ]; then echo OK; fi
-bash: [: missing `]' #不能直接用
[root@hadoop scripts]# if [ $a -gt 18 -a $a -lt 35 ]; then echo OK; fi
[root@hadoop scripts]# a=20
[root@hadoop scripts]# if [ $a -gt 18 -a $a -lt 35 ]; then echo OK; fi
OK
if [ 条件判断式 ]
then
程序
elif [ 条件判断式 ]
then
程序
else
程序
fi
判断属于哪个年龄段,双分支
[root@hadoop scripts]# vim if_test.sh
#!/bin/bash
if [ "$1"x = "zhangsan"x ]
then
echo "zhangsan"
fi
#输入第二个参数,表示年龄,判断属于哪个年龄段
if [ $2 -lt 18 ]
then
echo "未成年人"
else
echo "成年人"
fi
[root@hadoop scripts]# . if_test.sh zhangsan 15
zhangsan
未成年人
[root@hadoop scripts]# . if_test.sh zhangsan 25
zhangsan
成年人
判断属于哪个年龄段,多分支
注意事项:
①[ 条件判断式 ],中括号和条件判断式之间必须有空格
②if 后要有空格
1)基本语法
case $变量名 in
"值 1")
如果变量的值等于值 1,则执行程序 1
;;
"值 2")
如果变量的值等于值 2,则执行程序 2
;;
…省略其他分支…
*) 如果变量的值都不是以上的值,则执行此程序
;;
esac
输入数字,输出对应语句
[root@hadoop ~]# vim case_test.sh
#!/bin/bash
case $1 in
1)
echo "one"
;;
2)
echo "two"
;;
3)
echo "three"
;;
*)
echo "number else"
;;
esac
[root@hadoop ~]# chmod +x case_test.sh
[root@hadoop ~]# . case_test.sh
number else
[root@hadoop ~]# . case_test.sh 2
two
[root@hadoop ~]# . case_test.sh 1
one
[root@hadoop ~]# . case_test.sh 6
number else
注意事项:
(1)case 行尾必须为单词“in”,每一个模式匹配必须以右括号“)”结束。
(2)双分号“;;”表示命令序列结束,相当于 java 中的 break。
(3)最后的“*)”表示默认模式,相当于 java 中的 default。
for (( 初始值;循环控制条件;变量变化 ))
do
程序
done
从 1 加到 100,注意在for循环里面可以直接用数学运算符
[root@hadoop ~]# vim sum_to.sh
[root@hadoop ~]# cat sum_to.sh
#!/bin/bash
sum=0
for (( i=1; i <= $1; i++ ))
do
sum=$[ $sum + $i ]
done
echo $sum
[root@hadoop ~]# chmod +x sum_to.sh
[root@hadoop ~]# . sum_to.sh 100
5050
for 变量 in 值 1 值 2 值 3…
do
程序
done
[root@hadoop ~]# for i in {1..100}; do sum=$[$sum+$i]; done; echo $sum
5050
(2)比较$*和$@区别
$*和$@都表示传递给函数或脚本的所有参数,不被双引号“”包含时,都以$1 $2 …$n 的形式输出所有参数。
没加双引号,两种输出结果没有区别
[root@hadoop scripts]# vim parameter_for_test.sh
#!/bin/bash
echo '============$*================'
for para in $*
do
echo $para
done
echo '============$@================'
for para in $@
do
echo $para
done
[root@hadoop scripts]# chmod +x parameter_for_test.sh
[root@hadoop scripts]# . parameter_for_test.sh a b c d e
============$*================
a
b
c
d
e
============$@================
a
b
c
d
e
加双引号,两种输出结区别,一种有换行,一种没有换行。
当它们被双引号“”包含时,$*会将所有的参数作为一个整体,以“$1 $2 …$n”的形式输 出所有参数;$@会将各个参数分开,以“$1” “$2”…“$n”的形式输出所有参数。
[root@hadoop scripts]# vim parameter_for_test.sh
#!/bin/bash
echo '============$*================'
for para in "$*"
do
echo $para
done
echo '============$@================'
for para in "$@"
do
echo $para
done
[root@hadoop scripts]# . parameter_for_test.sh a b c d e
============$*================
a b c d e
============$@================
a
b
c
d
e
1)基本语法
while [ 条件判断式 ]
do
程序
done
2)案例实操
从1加到100
[root@hadoop scripts]# vim sum_to.sh
#!/bin/bash
#用for进行实现
sum=0
for (( i=1; i <= $1; i++ ))
do
sum=$[ $sum + $i ]
done
echo $sum
#用while做一个实现
a=1
while [ $a -le $1 ]
do
sum2=$[ $sum2 + $a ]
a=$[ $a + 1 ]
done
echo $sum2
[root@hadoop scripts]# . sum_to.sh 100
5050
5050
更简单语法用shell内嵌命令let
[root@hadoop scripts]# vim sum_to.sh
#用while做一个实现
sum2=0
a=1
while [ $a -le $1 ]
do
# sum2=$[ $sum2 + $a ]
# a=$[ $a + 1 ]
let sum2+=a
let a++
done
echo $sum2
[root@hadoop scripts]# . sum_to.sh 100
5050
5050