shell脚本获取指定目录下指定格式文件数量和名称
#!/bin/bash
#创建一个集合存放遍历出来的数据
zip_list=()
controller_tar(){
for file in `ls 指定文件夹的绝对路径`
do
#贪婪匹配文件后缀名是否为zip或者gz
if [ "${file##*.}"x = "zip"x ]||[ "${file##*.}"x = "gz"x ]
then
#如果符合条件将文件放入集合中
zip_list[${#zip_list[*]}]=${file}
fi
done
}
#调用方法
controller_tar
#输出所有符合要求的文件名称
echo ${zip_list[*]}
#输出所有符合要求的文件总数量
echo ${zip_list[@]}
引申知识点:
贪婪匹配和非贪婪匹配
非贪婪匹配:
现在有一个字符串v以下是非贪婪匹配的shell脚本写法
v=jpp.shell.com
echo ${v%.*}
最终输出的结果为:jpp.shell
一个%为非贪婪匹配,即匹配最短结果。%从右到左进行非贪婪匹配,匹配什么呢? 匹配已 .的字符。 那么当然是匹配到了.com 然后执行删除匹配到的字符。结果就是(这里的 “.” 相当于定界符。而“”是通配符),
贪婪匹配:
echo ${v%%.*}
输出结果:jpp
两个%为贪婪匹配,即匹配最长结果。
这里在说一个 # 刚好和 %顺序相反而已,#是从左到右来进行匹配的。来举个例子
非贪婪匹配
v=jpp.shell.com
echo ${v#.*}
最终输出的结果为:jpp
贪婪匹配
v=jpp.shell.com
echo ${v##.*}
最终输出结果com
最后再补充一些
${#VALUE}:计算VALUE字符串的字符数量。
KaTeX parse error: Expected '}', got 'EOF' at end of input: {VALUE%.*}或{VALUE%%.}:删除VALUE字符串中以分隔符“.”匹配的右边字符,保留左边字符。
KaTeX parse error: Expected '}', got '#' at position 7: {VALUE#̲*.}或{VALUE##.}:删除VALUE字符串中以分隔符“.”匹配的左边字符,保留右边字符。
V A L U E / O L D / N E W 或 {VALUE/OLD/NEW}或 VALUE/OLD/NEW或{VALUE//OLD/NEW}:用NEW子串替换VALUE字符串中匹配的OLD子串。
补充:“*”表示通配符,用于匹配字符串将被删除的字串。“.”表示字符串中分隔符,可以为任意一个或多个字符。“%”表示从右向左匹配,“#”表示从左向右匹配,“\”表示替换,都属于非贪婪匹配,即匹配符合通配符的最短结果。与“%”、“#”和“/”类似的有“%%”、“##”和“//”,都属于贪婪匹配,即匹配符合通配符的最长结果。
V A L U E : O F F S E T 或 {VALUE:OFFSET}或 VALUE:OFFSET或{VALUE:OFFSET:LENGTH}:从VALUE字符串的左边开始中截取子串。
V A L U E : 0 − O F F S E T 或 {VALUE:0-OFFSET}或 VALUE:0−OFFSET或{VALUE:0-OFFSET:LENGTH}:从VALUE字符串的右边开始中截取子串。
补充:左边第一个字符从“0”开始,右边第一个字符从“0-1”开始。 表示偏移OFFSET个字符开始,LENGTH表示要截取字符的长度。如果没有LENGTH变量,表示偏移OFFSET个字符开始到字符串结束。
${VALUE:-WORD}:当变量未定义或者值为空时,返回值为WORD的内容,否则返回变量的值。
${VALUE:=WORD}:当变量未定义或者值为空时,返回WORD的值的同时并将WORD赋值给VALUE,否则返回变量的值。
${VALUE:+WORD}:当变量已赋值时,其值才用WORD替换,否则不进行任何替换。
${VALUE:?MESSAGE}:当变量已赋值时,正常替换。否则将消息MESSAGE送到标准错误输出(若此替换出现在SHELL程序中,那么该程序将终止运行)