前言:
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
输出为:
aest1.sh 2. 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
未完待续!!!