linux shell中各类括号的使用方法

from:http://www.cnblogs.com/hanyan225/archive/2011/10/06/2199652.html

    在Shell中的小括号,大括号结构和有括号的变量,命令的用法以下:
1.${var}
2.$(cmd)
3.()和{}
4.${var:-string},${var:+string},${var:=string},${var:?string}
5.$((exp))
6.$(var%pattern),$(var%%pattern),$(var#pattern),$(var##pattern)
    如今来一一详细介绍:
    1)Shell中变量的原形
       这个最多见的变量形式就是$var,打印var用命令
       echo $var
    但是这里有个问题:当你要显示变量值加随意的字符(如$varAA)时,就会出错。系统会认为整个varAA是一个变量,这时就能够用一个大括号来限定变量名称的范围,如${var}AA,这样就行了。
    2)命令替换$(cmd)
    命令替换$(cmd)和符号`cmd`(注意这不是单引号,在美式键盘上,`是ESC下面的那个键)有相同之处.以echo $(ls)来讲明整个替换过程:shell扫描一遍命令行,发现了$(cmd)结构,便将$(cmd)中的cmd执行一次,获得其标准输出,再将此输出放 到原来命令echo $(ls)中的$(ls)位置,即替换了$(ls),再执行echo命令。以下:
1 $ ls
2 a b c
3 $ echo $(ls)
4 a b c
5 $ echo `ls`
6 a b c
    3)一串的命令执行()和{}
      ()和{}都是对一串的命令进行执行,但有所区别:
A,()只是对一串命令从新开一个子shell进行执行
B,{}对一串命令在当前shell执行
C,()和{}都是把一串的命令放在括号里面,而且命令之间用;号隔开
D,()最后一个命令能够不用分号
E,{}最后一个命令要用分号
F,{}的第一个命令和左括号之间必需要有一个空格
G,()里的各命令没必要和括号有空格
html

H,()和{}中括号里面的某个命令的重定向只影响该命令,但括号外的重定向则影响到括号里的全部命令正则表达式


    4)几种特殊的替换结构:${var:-string},${var:+string},${var:=string},${var:?string}
      A,${var:-string}和${var:=string}:若变量var为空,则用在命令行中用string来替 换${var:-string},不然变量var不为空时,则用变量var的值来替换${var:-string};对于${var:=string}的 替换规则和${var:-string}是同样的,所不一样之处是${var:=string}若var为空时,用string替 换${var:=string}的同时,把string赋给变量var: ${var:=string}很经常使用的一种用法是,判断某个变量是否赋值,没有的话则给它赋上一个默认值。
      B. ${var:+string}的替换规则和上面的相反,即只有当var不是空的时候才替换成string,若var为空时则不替换或者说是替换成变量 var的值,即空值。(由于变量var此时为空,因此这两种说法是等价的)
      C,${var:?string}替换规则为:若变量var不为空,则用变量var的值来替换${var:?string};若变量var为空,则把string输出到标准错误中,并从脚本中退出。咱们可利用此特性来检查是否设置了变量的值。
      补充扩展:在上面这五种替换结构中string不必定是常值的,可用另一个变量的值或是一种命令的输出。
     5)POSIX标准的扩展计算:$((exp))
      这种计算是符合C语言的运算符,也就是说只要符合C的运算符均可用在$((exp)),甚至是三目运算符。注意:这种扩展计算是整数型的计算,不支持浮点型.如果逻辑判断,表达式exp为真则为1,假则为0。
     6)四种模式匹配替换结构:${var%pattern},${var%%pattern},${var#pattern},${var##pattern}
     第一种模式:${variable%pattern},这种模式时,shell在variable中查找,看它是否一给的模式pattern结尾,若是是,就从命令行把variable中的内容去掉右边最短的匹配模式
     第二种模式: ${variable%%pattern},这种模式时,shell在variable中查找,看它是否一给的模式pattern结尾,若是是,就从命令行把variable中的内容去掉右边最长的匹配模式
     第三种模式:${variable#pattern} 这种模式时,shell在variable中查找,看它是否一给的模式pattern开始,若是是,就从命令行把variable中的内容去掉左边最短的匹配模式
     第四种模式: ${variable##pattern} 这种模式时,shell在variable中查找,看它是否一给的模式pattern结尾,若是是,就从命令行把variable中的内容去掉右边最长的匹配模式
     这四种模式中都不会改变variable的值,其中,只有在pattern中使用了*匹配符号时,%和%%,#和##才有区别。结构中的pattern支 持通配符,*表示零个或多个任意字符,?表示零个或一个任意字符,[...]表示匹配中括号里面的字符,[!...]表示不匹配中括号里面的字符
view sourceprint?
01 [root@root shell]# var=testcase
02 [root@root shell]# echo $var
03 testcase
04 [root@root shell]# echo ${var%s*e} 从最右边删除最短匹配
05 testca
06 [root@root shell]# echo $var
07 testcase
08 [root@root shell]# echo ${var%%s*e} 从最右边删除最长匹配
09 te
10 [root@root shell]# echo $var  变量没有改变
11 testcase
12 [root@root shell]# echo ${var#?e} 从最左边删除最短匹配
13 stcase
14 [root@root shell]# echo $var
15 testcase
16 [root@root shell]# echo ${var#*e}  从最左边删除最短匹配
17 stcase
18 [root@root shell]# echo $var
19 testcase
20 [root@root shell]# echo ${var##*e} 从最左边删除最长匹配,即删除全部
21 [root@root shell]# echo $var
22 testcase
23 [root@root shell]# echo ${var##*s} 从最左边删除最长匹配
24 e
25 [root@root shell]# echo $var
26 testcase
27 [root@root shell]# echo ${var#test} 删除test
28 case
29 [root@root shell]# echo $var
30 testcase
31 [root@root shell]# echo ${var#tests} 没有匹配
32 testcase
shell

//---------------------分割线,下文为笔记内容-------------------------ide

变量相关的命令spa

export, readonly命令行

export:用于修改或打印变量htm

readonly:设置变量为只读blog

 

替换运算符进程

${var:-word}     若是var存在且非null,返回它的值;不然返回wordcmd

${var:=word}   若是var存在且非null,返回它的值;不然将word赋值给var,并返回var的值 

${var:?word}    若是var存在且非null,返回它的值;不然显示var:word

${var:+word}     若是var存在且非null,返回word;不然返回null

 

注:冒号(:)可省略

 

模式匹配运算符

${var#pattern}    匹配前缀(最小匹配),并返回余下内容

${var##pattern}    匹配前缀(最大匹配),并返回余下内容

${var%pattern}    匹配结尾(最小匹配),并返回余下内容

${var%%pattern}    匹配结尾(最大匹配),并返回余下内容

 

注:pattern为正则表达式匹配

 

算术运算符

Shell的算术运算符基本上与C一致,就很少说了。

算术运算符能够放置在$((...))里面,也就是内嵌算术,也称为算术展开。譬如 echo $((2>1)) 打印结果为1。(1表示真,0表示假)

 

特殊变量

$#    表示变量的个数,经常使用于循环

$@    当前命令行全部参数。置于双引号中,表示个别参数

$*    当前命令行全部参数。置于双引号中,表示将命令行全部参数当初一个单独参数

$-(连字号)    在引用数给予Shell的选项

$?    表示上一个命令退出的状态

$$    表示当前进程编号

$0    表示当前程序名称

$!    表示最近一个后台命令的进程编号

$HOME    表示当前用户根目录

$IFS    表示内部的字段分隔符

$LANG    当前locale默认名称

$PATH    环境变量

$PPID    父进程编号

$PWD    当前工做目录

 

$?的参考值

0    成功退出

>0    退出失败

1-125    命令退出失败,失败返回的相关值由程序定义(譬如,程序内退出只执行 exit 2,则返回为2)

126    命令找到了,但没法执行

127    命令找不到

>128    命令因受到信号而死亡

相关文章
相关标签/搜索