linux shell
shell脚本的流程控制语句的实现
一、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
到此这篇关于shell脚本的流程控制语句的实现的文章就介绍到这了,更多相关shell 流程控制语句 内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!