IT码农库

您当前所在位置:首页 > 脚本专栏 > linux shell

linux shell

shell脚本的流程控制语句的实现

[db:来源] 2022-08-22linux shell5824
本文主要介绍了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 流程控制语句 内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!

大图广告(830*140)