shell贪婪匹配

有时候对一段文字只提取其中的一部分,可以借助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

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注