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

欢迎补充指正!

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值