linux|shell编程|shell脚本的一些高级技巧(shell脚本内的括号,中括号,花括号,逻辑判断,脚本优雅退出等等)

前言:

shell脚本说容易其实也是容易的,说难,那真的是可以难到让人挠头的地步,因为逻辑判断,自定义变量,环境变量,系统内置函数,脚本结构设计这些糅合到一起后,脚本可能会变的非常复杂了。

那么,本文主要就shell脚本内使用系统函数(dirname,basename,exit),逻辑判断符号,gt,lt,eq,ne,ge,le,n,r,x,w,e,d,f ,z,变量包裹符 ()[] {} [[]] ` 这些内容做一个粗略的介绍

一,

变量的定义

例如,定义一个变量a,该变量的值是10

a=10

错误定义(两头有空格是错误的e):

[root@EULER2 ~]# a =2
-bash: a: command not found
^[[6~[root@EULER2 ~]# a= 2
-bash: 2: command not found

那么,这种定义方式是最简单的,需要注意,变量名称和变量值之间的=号两边不能有空格 

OK,结合实际的工作来说,变量肯定不能这么简单了,比如,定义一个变量b,给它赋值某个文本文件的内容(这里用的是反引号)

[root@EULER2 ~]# b=`cat test.sh `
[root@EULER2 ~]# echo $b
#!/bin/bash a=12 b=12 if [ $a -eq $b ]; then echo "bianliang a dengyu bianliang b " else echo "bianliang a budengyu bianliang b " fi

第二种定义方式($符合结合单括号):

[root@EULER2 ~]# b=$(cat test.sh)
[root@EULER2 ~]# echo $b
#!/bin/bash a=12 b=12 if [ $a -eq $b ]; then echo "bianliang a dengyu bianliang b " else echo "bianliang a budengyu bianliang b " fi

那么,这两种方式有何不同?到底用哪种比较合适呢?

效果基本是相同的,只是反引号是一个老的用法,$( ) 是 新 的 用 法 , 无 论 是 在 学 习 还 是 实 际 工 作 中 , 建议还是使用$(),理由如下:

1,

反引号容易和引号混淆

2,

反引号处理特殊字符的时候需要多写一个转义符,例如

[root@EULER2 ~]# echo $HOSTNAME
EULER2
[root@EULER2 ~]# b=`echo $HOSTNAME`
[root@EULER2 ~]# echo $b
EULER2

此时,如果只想输出$HOSTNAME 而不是EULER2,那么,应该使用双层转义符

[root@EULER2 ~]# b=`echo \\$HOSTNAME`
[root@EULER2 ~]# echo $b
$HOSTNAME

单层转义符并没有什么用:

[root@EULER2 ~]# b=`echo \$HOSTNAME`
[root@EULER2 ~]# echo $b
EULER2

而$()只需要一个转义符就可以了,但需要考虑的是反引号书写更为简单。

二,

逻辑判断符

逻辑判断符主要用在脚本的if语句,while循环,for循环,case选择这些语句内,也就是通常是内嵌在这些语句内的。从而控制这些语句的运行方向(例如,是否跳出循环,是否进入下一个条件等等),具体的实施中其实也就是两个变量的值的逻辑判断,判断两者的值是否大于(gt),大于等于(ge),等于(eq),小于(lt),小于等于(le),字符串长度为零(z),字符串长度非零(n)这些逻辑关系。

1,-gt -ge

-gt   判断某个变量是否大于某个值

-ge  判断某个变量是否大于或者等于某个值

那么,/etc/profile这个脚本文件是比较全面的,部分逻辑判断符就以此文件做示例吧

if [ $UID -gt 199 ] && [ "`/usr/bin/id -gn`" = "`/usr/bin/id -un`" ]; then
    umask 002
else
    umask 022
fi

这一段shell代码表示当uid仅大于199的时候,umask的值是002,小于等于199的时候,umask的值是022

2,

-lt -le

-lt 判断某个变量的值是否小于某个数值

-le 判断某个变量的值是否小于等于某个数值

例如下面的脚本:

#!/bin/bash
a=20
if [ $a -lt 15 ];
then
echo "bianliang a shi xiaoyu 15de "
else
echo "bianliang a shi dayu 15de "
fi

很明显,20小于15为假,因此,输出的是else后面的代码

3,

-z和-n和$变量

-z判断字符串的长度是否为零,为0返回真

-n判断字符串的长度是否不为零,不为0返回真

$变量同-n,判断字符串的长度是否不为零,不为0返回真

-z的示例(特别注意,使用了双引号):

#!/bin/bash
a=shiguang
b=""
if [ -z $a ];
then
echo "a zifuchuan wei kong"
else
echo "a zifuchuan you neirong"
fi
if [ -z $b ];
then
echo "b zifuchuan wei kong"
else
echo "b zifuchuan you neirong"
fi
[root@EULER2 ~]# bash test.sh 
a zifuchuan you neirong
b zifuchuan wei kong

-n的示例(特别注意,使用了双引号)

[root@EULER2 ~]# bash test.sh 
a zifuchuan you
b zifuchuan meiyou
#!/bin/bash
a=shiguang
b=""
if [ -n "$a" ];
then
echo "a zifuchuan you"
else
echo "a zifuchuan meiyou"
fi
if [ -n "$b" ];
then
echo "b zifuchuan you"
else
echo "b zifuchuan meiyou"
fi

$变量的示例(尽量使用""双引号包裹,本例没有使用双引号,其实是不规范的):

#!/bin/bash
a="shiguang"
if [ $a ];
then
echo "a bu kong"
else
echo "a kong"
fi
[root@EULER2 ~]# bash test1.sh 
a bu kong

####:注,如果是双中括号,不需要双引号包裹变量,否则需要双引号包裹变量,例如:

#!/bin/bash
a=""
if [[ $a ]];
then
echo "a bu kong"
else
echo "a kong"
fi

输出为:

[root@EULER2 ~]# bash test1.sh 
a kong

4,

=  ==  -eq

这三个都是等于的判断,但需要注意它们的使用范围,==可以比较判断字符串和整数数字,-eq只可以比较判断整数数字,也就是说-eq的范围会比较窄,=也可以比较判断字符串和整数数字,在算数运算表达式“(( ))”中,单等号是赋值算数运算符,双等号为相等算数运算符,可以这么认为它们的使用范围:== 大于 = 大于 -eq ,另外,在逻辑判断时,一般是使用双中括号的,不使用单中括号

例子如下:

#!/bin/bash
a="shiguang"
b="shiguang"
if [[ $a = $b ]];
then
echo "a dengyu b"
else
echo "a budengyu b"
fi

未完待续!!!

猜你喜欢

转载自blog.csdn.net/alwaysbefine/article/details/131644367
今日推荐