有時候對一段文字只提取其中的一部分,可以藉助shell的貪婪匹配實現,%是從右向左匹配,#則是從左向右匹配,如下執行個體:
[root@www ~]# qq=www.qq.com
[root@www ~]# echo ${qq#*.} //排除第一個
qq.com
[root@www ~]# echo ${qq##*.} //排除前兩個
com
[root@www ~]# echo ${qq%.*} //排除後一個
www.qq
[root@www ~]# echo ${qq%%.*} //排除後兩個
www
[root@www ~]#
以上是一個簡單的執行個體,下面來看一個具體的指令碼中的使用
# vim test.sh
# chmod +x test.sh
# cat test.sh
#!/bin/bashnum=1for i in *.tar *.tar.gzdonew=new_$num.${i#*.} mv $i $new 2>/dev/nullif [ $? -eq 0 ];then echo "remove $i to $new" let num++fi done
# touch test{1..5}.tar test{1..5}.tar.gz
# ls
test1.tar test2.tar test3.tar test4.tar test5.tar test.sh
test1.tar.gz test2.tar.gz test3.tar.gz test4.tar.gz test5.tar.gz
# ./test.sh
remove test1.tar to new_1.tar
remove test2.tar to new_2.tar
remove test3.tar to new_3.tar
remove test4.tar to new_4.tar
remove test5.tar to new_5.tar
remove test1.tar.gz to new_6.tar.gz
remove test2.tar.gz to new_7.tar.gz
remove test3.tar.gz to new_8.tar.gz
remove test4.tar.gz to new_9.tar.gz
remove test5.tar.gz to new_10.tar.gz
#