bash(一): shell中括号,引号的用法

bash中if的几种用法

 

if command

then

       command

fi

 

 

test for number and strings

if test expression

then

      command

fi

 

or

 

if [ string/numeric expression ]  then

    command

fi

 

 

test for strings

if[[ string expression ]]   then

    command

fi

 

 

 

let for numbers

if (( numeric expression ))

 

 

if [ $answer = Y -o "$answer" = y ]

    [: too many arguments
$answer 与 "$answer"的不同在于加双引号后只当做singel string,如果test命令的左边是多个string就会出错。

 

老式的[]只能用-a来表示与,而新式的可以用&&来表示与。

 

if中的Null运算符

:

列子

DATAFIL=

: ${DATAFILE:=$HOME/db/datafile}

echo $DATAFILE

 

:${DATAFILE:=$HOME/junk}

echo $DATAFILE

:相当于一个空函数,${DATAFILE:=$HOME/db/datafile}相当于往函数中传递参数,:=叫做modifier,如果DATAFILE不为空,则不会被赋值,否则就会被赋值。

 APEND:

shell中的括号比较多,总结下主要的用法:
1、变量原型$

例如:

#!/bin/bash

tail={GetProperty(Content)} 
for filename in `ls` 
do 
  
 mv $filename ${filename}.$tail 
done 

2、$()   命令替换

命令替换: 等同于 `cmd` : shell扫描一遍命令行,发现了$(cmd)结构,便将$(cmd)中的cmd执行一次,得到其标准输出,再将此输出放到原来命令

3、一串的命令执行()和{}

a ()只是对一串命令重新开一个子shell进行执行,{}对一串命令在当前shell执行

b ()和{}都是把一串的命令放在括号里面,并且命令之间用;号隔开

c ()最后一个命令可以不用分号, {}最后一个命令要用分号

d {}的第一个命令和左括号之间必须要有一个空格,()里的各命令和括号不必有空格

e ()和{}中括号里面的某个命令的重定向只影响该命令,但括号外的重定向则影响到括号里的所有命令

$ var=test

$ (var=notest; echo $var)       ###变量var值为notest,只是在子shell中有效,

notest

$ echo $var                          ###变量var在父shell中值仍为test

test

$ { var=notest; echo $var;}     ###注意左括号和var之间要有一个空格

notest

$ echo $var                ###父shell中的var变量的值变为了notest

notest

$ { var1=test1;var2=test2;echo $var1>a;echo $var2;}    ###输出test1被重定向到文件a中,

test2                                       ###而test2输出则仍输出到标准输出中。

$ cat a

test1

$ { var1=test1;var2=test2;echo $var1;echo $var2;}>a             ###括号内命令的标准输出全部被重定向到文件a中

$ cat a

test1

test2

4、POSIX标准的扩展计算:$((exp))

这种计算是符合C语言的运算符,也就是说只要符合C的运算符都可用在$((exp)),甚至是三目运算符。

注意:这种扩展计算是整数型的计算,不支持浮点型.若是逻辑判断,表达式exp为真则为1,假则为0。

$ echo $((3+2))

5

$ echo $((3>2))                  ###逻辑判断

1

$ echo $((25<3 ? 2:3))

3

$ echo $var

$ echo $((var=2+3))

5

$ echo $var

5

$ echo $((var++))

5

$ echo $var

6

5、中括号:test [] [[]]

a. test 和 [ 是 bash 的内部命令,[和test是等同的。如果我们不用绝对路径指明,通常我们用的都是 bash 自带的命令。

Test和[]中可用的比较运算符只有==和!=,两者都是用于字符串比较的,不可用于整数比较,整数比较只能使用-eq, -gt这种形式。无论是字符串比较还是整数比较都千万不要使用大于号小于号。当然,如果你实在想用也是可以的,对于字符串比较可以使用尖括号的转义形式,如果比较"ab"和"bc":[ ab \< bc ],结果为真,也就是返回状态为0.

b. [[ 是 bash 程序语言的关键字

[ ]],这是内置在shell中的一个命令,比test强大的多了。支持字符串的模式匹配(使用=~操作符时甚至支持shell的正则表达式)。

字符串比较时可以把右边的作为一个模式,而不仅仅是一个字符串,比如[[ hello == hell? ]],结果为真。

 [[ 中使用 && 和 || ,[ 中使用 -a 和 -o 表示逻辑与和逻辑或。

[[ 中匹配字符串或通配符,不需要引号 .    [ 不能使用正则

#!/bin/bash

echo ${var:=string}

if [[ $var ==   str* ]]

运行结果为 yes

#!/bin/bash

echo ${var:=string}

if [ $var == str   -o $var != str ]    ## 需要使用单括号,使用双括号的形式为:if [[ $var == str ]] ||   [[ $var != str ]]

6、特殊用法:

${var:-string}若变量var为空,则在命令行中用string来替换$,var本身的值不变;否则变量var不为空时,则用变量var的值来替换$
${var:=string}与上是一样的,所不同之处是:若var为空时,用string替换$的同时,把string赋给变量var。

${var:+string}的替换规则和上面的相反,即只有当var不是空的时候才替换成string,但是var本身的值不变; 若var为空时则不替换或者说是替换成变量 var的值,即空值。(因为变量var此时为空,所以这两种说法是等价的)

${var:?string}若变量var不为空,则用变量var的值来替换$;若变量var为空,则把string输出到标准错误中,并从脚本中退出。我们可利用此特性来检查是否设置了变量的值。

 

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值