看到这样一句脚本
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
欢迎补充指正!