linux带⽅括号进程,linuxshell中各种括号的使⽤⽅法
在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
2a b c
3$ echo $(ls)
4a b c
5$ echo `ls`
6a b c
3)⼀串的命令执⾏()和{}
()和{}都是对⼀串的命令进⾏执⾏,但有所区别:
A,()只是对⼀串命令重新开⼀个⼦shell进⾏执⾏
B,{}对⼀串命令在当前shell执⾏
C,()和{}都是把⼀串的命令放在括号⾥⾯,并且命令之间⽤;号隔开
D,()最后⼀个命令可以不⽤分号
E,{}最后⼀个命令要⽤分号
F,{}的第⼀个命令和左括号之间必须要有⼀个空格
G,()⾥的各命令不必和括号有空格
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
03testcase
04[root@root shell]# echo ${var%s*e} 从最右边删除最短匹配
05testca
06[root@root shell]# echo $var
07testcase
08[root@root shell]# echo ${var%%s*e} 从最右边删除最长匹配
09te
10[root@root shell]# echo $var  变量没有改变
11testcase
12[root@root shell]# echo ${var#?e} 从最左边删除最短匹配
13stcase
14[root@root shell]# echo $var
15testcase
16[root@root shell]# echo ${var#*e}  从最左边删除最短匹配
17stcase
18[root@root shell]# echo $var
19testcase
20[root@root shell]# echo ${var##*e} 从最左边删除最长匹配,即删除所有
21[root@root shell]# echo $var
22testcase
23[root@root shell]# echo ${var##*s} 从最左边删除最长匹配
24e
25[root@root shell]# echo $var
26testcase
27[root@root shell]# echo ${var#test} 删除test
28case
29[root@root shell]# echo $var
30testcase
31[root@root shell]# echo ${var#tests} 没有匹配
32testcase
//---------------------分割线,下⽂为笔记内容-------------------------
变量相关的命令
export, readonly
export:⽤于修改或打印变量
readonly:设置变量为只读
替换运算符
${var:-word}    如果var存在且⾮null,返回它的值;否则返回word
${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    环境变量
linux所有命令都无法使用$PPID    ⽗进程编号
$PWD    当前⼯作⽬录
$?的参考值
0    成功退出
>0    退出失败
1-125    命令退出失败,失败返回的相关值由程序定义(譬如,程序内退出只执⾏ exit 2,则返回为2)
126    命令到了,但⽆法执⾏
127    命令不到
>128    命令因受到信号⽽死亡

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。