有时候对一段文字只提取其中的一部分,可以借助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 ~]#
上例中是以点为分割的,不是以“qq”做为分割 。下面结合实际应用中的应用再进行下介绍。
先新建几个文件:
# 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
构建使用脚本:
# cat test.sh #!/bin/bash num=1 for i in *.tar *.tar.gz do new=new_$num.${i#*.} mv $i $new 2>/dev/null if [ $? -eq 0 ];then echo "remove $i to $new" let num++ fi done
执行后的输出为:
# ./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 #
查看更改效果:
[root@localhost media]# ls new_10.tar.gz new_1.tar new_2.tar new_3.tar new_4.tar new_5.tar new_6.tar.gz new_7.tar.gz new_8.tar.gz new_9.tar.gz test.sh