对于访问 $9 之后的位置参数也同样需要使用大括号,比如:
echo "Argument 1 is $1"
echo "Argument 10 is ${10}"
间接参数扩展:
${!PARAMETER}
上述语句中,被引用的参数不是 PARAMETER 自身,而是 PARAMETER 的值。比如,如果参数 PARAMETER 的值是 TEMP,则 ${!PARAMETER} 将扩展为参数 TEMP 的值:
大小写修改:
${PARAMETER^}
${PARAMETER^^}
${PARAMETER,}
${PARAMETER,,}
${PARAMETER~}
${PARAMETER~~}
上述语句中的这些扩展操作符修改参数值中字母的大小写。“”将参数值的第一个字符改为大写,“,”将参数值的第一个字符改为小写,“~”将参数值的第一个字符转换为相反的大小写。当使用双重模式(^、,,和~~)时,参数值的所有字符都将被转换。
下面的实例中,将当前目录下的所有后缀为 txt 的文件名转换为小写:
for file in *.txt; do mv "$file" "${file,,}"; done
运行实例:
变量名扩展
${!PREFIX*}
${!PREFIX@}
这种扩展将列出以字符串 PREFIX 开头的所有变量名。默认情况下列出的这些变量名之间将以空格分隔。
字符串移除
${PARAMETER#PATTERN}
${PARAMETER##PATTERN}
${PARAMETER%PATTERN}
${PARAMETER%%PATTERN}
前两个语句用于移除从参数值得开头匹配指定模式的字符串,而后两个语句与之相反,用于从参数值的末尾匹配指定模式的字符串。操作符 “#” 和 “%” 表示将移除匹配指定模式的最短文本,而操作符 “##” 和 “%%”表示移除匹配指定模式的最长文本。例如下面的示例(注意 Shell 语句中的空格):
这种扩展常常被用于提取文件名:
字符串搜索与替换
${PARAMETER/PATTERN/STRING}
${PARAMETER//PATTERN/STRING}
${PARAMETER/PATTERN}
${PARAMETER//PATTERN}
这种参数扩展可以替换参数值中匹配指定模式的子字符串。操作符 “/” 表示只替换一个匹配的字符串,而操作符 “//” 表示替换所有匹配的字符串。如果没有指定替换字符串 STRING,那么匹配的内容将会被替换为空字符串,即被删除。下面是使用示例(注意语句中的空格):
计算字符串的长度
${#PARAMETER}
子字符串扩展
${PARAMETER:OFFSET}
${PARAMETER:OFFSET:LENGTH}
从指定的位置开始截取指定长度的字符串,如果省略 LENGTH,将截取到参数值得末尾。示例:
使用默认值
${PARAMETER:-WORD}
${PARAMETER-WORD}
如果参数 PARAMETER 未定义,或为 null 时,这种模式会扩展 WORD,否则将扩展参数 PARAMETER。如果省略符号 “:“,即第二种形式,只有参数 PARAMETER 是未定义时,才会使用 WORD。示例:
指定默认值
${PARAMETER:=WORD}
${PARAMETER=WORD}
使用示例:
使用替代值
${PARAMETER:+WORD}
${PARAMETER+WORD}
如果参数 PARAMETER 是未定义的,或其值为空时,这种模式将不扩展任何内容。如果参数 PARAMETER 时定义的,且其值不为空时,这种模式将扩展 WORD,而不是扩展为参数 PARAMETER 的值。如下示例所示:
本文参考自 《Linux Shell命令行及脚本编程实例详解 》