shell 流程控制语句
lambda-小张 人气:0一、if 判断
1)基本语法
(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
(2)多分支
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 后要有空格
二、case 语句
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 循环
1)基本语法1
for (( 初始值;循环控制条件;变量变化 ))
do
程序
done
2)案例实操
从 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
3)基本语法 2
for 变量 in 值 1 值 2 值 3…
do
程序
done
[root@hadoop ~]# for i in {1..100}; do sum=$[$sum+$i]; done; echo $sum 5050
(4)比较$*和$@区别
$*和$@都表示传递给函数或脚本的所有参数,不被双引号“”包含时,都以$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
四、while循环
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
加载全部内容