Bash中的字符串截取

看到这样一句脚本

APP_NAME="${0##*[\\/]}"

起初不知道什么意思,后来才发现,这是在截取文件名.
假如我们的脚本叫test.sh :

#!/bin/bash 
appName="${0##*[\\/]}"

echo $appName

那么:

# 以相对路径运行
[root@localhost Downloads]# ./test.sh 
test.sh

# 以绝对路径运行
[root@localhost Downloads]# /root/Downloads/test.sh 
test.sh

那么为什么${0##*[\\/]}可以截取文件名呢?
这就要说下bash中的子串截取规则了:

语法 说明
${varible#*str} 从左往右,删除最短的一个以string结尾的子串,即截取一个string子串之后的字符串
${varible##*str} 从左往右,删除最长的一个以string结尾的子串,即截取最后一个string子串之后的字符串
${varible%str*} 从右往左,删除最短的一个以string开头的子串,即截取最后一个string子串之前的字符串
${varible%%str*} 从右往左,删除最长的一个以string开头的子串,即截取一个string子串之前的字符串

那么对于${0##*[\\/]}而言,就是取$0(也就是键入的脚本名,无论以什么路径),
删除从开始 到最后一个/或者\,也就是只留文件名,不留路径,即上述输出test.sh.
事实上写成${0##*/}也可以.

那么来做个实验,验证下上述表格中的观点:

# 定义字符串testStr
[root@localhost Downloads]# testStr=0123abc456789abcdef.xyz

# 从左往右,删除0123abc
[root@localhost Downloads]# echo ${testStr#*abc}
456789abcdef.xyz

# 从左往右,删除0123abc456789abc
[root@localhost Downloads]# echo ${testStr##*abc}
def.xyz

# 从右往左,删除abcdef.xyz
[root@localhost Downloads]# echo ${testStr%abc*}
0123abc456789

# 从右往左,删除abc456789abcdef.xyz
[root@localhost Downloads]# echo ${testStr%%abc*}
0123
[root@localhost Downloads]# 

还有一种按索引和长度截取方法:
${varible:startIndex:len},类似于js中的substr方法:

[root@localhost Downloads]# testStr=123abc456

# 从索引2开始,取3个字符
[root@localhost Downloads]# echo ${testStr:2:3}
3ab

参考:
http://blog.csdn.net/finewings/article/details/5718133

欢迎补充指正!

相关文章

用的openwrt路由器,家里宽带申请了动态公网ip,为了方便把2...
#!/bin/bashcommand1&command2&wait从Shell脚本并行...
1.先查出MAMP下面集成的PHP版本cd/Applications/MAMP/bin/ph...
1、先输入locale-a,查看一下现在已安装的语言2、若不存在如...
BashPerlTclsyntaxdiff1.进制数表示Languagebinaryoctalhexa...
正常安装了k8s后,使用kubect工具后接的命令不能直接tab补全...