Linux中使用 ${来修改变量}
小提示:Linux的变量修改方式类似于正则表达式,匹配到字符后删除或者用新字符来替换就字符
表达式 | 说明 |
---|---|
${变量名#匹配字串} |
从头向后开始匹配,删除符合匹配字串的最短数据 |
${变量名##匹配字串} |
从头向后开始匹配,删除符合匹配字串的最长数据 |
${变量名%匹配字串} |
从尾向前开始匹配,删除符合匹配字串的最短数据 |
${变量名%%匹配字串} |
从尾向前开始匹配,删除符合匹配字串的最长数据 |
${变量名/旧的字串/新的字串} |
将符合旧字串的第一个字串替换为新的字串 |
${变量名//旧的字串/新的字串} |
将符合旧字串的全部字串替换为新的字串 |
例子
要测试的变量
teststr
='123456789myvar@qq.com'
code5@code5-debian:~$ teststr='123456789myvar@qq.com'
code5@code5-debian:~$ echo $teststr
123456789myvar@qq.com
code5@code5-debian:~$
1、从头向后开始匹配(#)
从头向后开始匹配:从第一个字符开始匹配
${变量名#匹配字串} 从头向后开始匹配,删除符合匹配字串的最短数据
正确匹配
code5@code5-debian:~$ echo ${teststr#123}
456789myvar@qq.com
匹配到123并删除
错误匹配
code5@code5-debian:~$ echo ${teststr#234}
123456789myvar@qq.com
code5@code5-debian:~$
从第一位字符开始匹配,无法匹配成功
2、从头向后开始匹配(##)
${变量名##匹配字串} 从头向后开始匹配,删除符合匹配字串的最长数据
最长数据:从第一个字符开始尽可能的匹配最多的字符
## 与 # 作用差不多,都是从第一个字符开始匹配,但 ## 会尽可能多的匹配字符
# 的匹配
code5@code5-debian:~$ echo ${teststr#1*m}
yvar@qq.com
##的匹配
code5@code5-debian:~$ echo ${teststr##1*m}
code5@code5-debian:~$
# 与 ## 对比
3、从尾向前开始匹配(%)
${变量名%匹配字串} 从尾向前开始匹配,删除符合匹配字串的最短数据
与
#
作用差不多,但%
从最后一个字符开始匹配
正确匹配
code5@code5-debian:~$ echo ${teststr%com}
123456789myvar@qq.
code5@code5-debian:~$
匹配到com并删除
错误匹配
code5@code5-debian:~$ echo ${teststr%".co"}
123456789myvar@qq.com
4、从尾向前开始匹配(%%)
${变量名%%匹配字串} 从尾向前开始匹配,删除符合匹配字串的最长数据
%%
与##
差不多,但%%
从字符串末尾开始匹配,并尽可能的匹配更多的字符,具体例子参考##
,这里不举例子
5、字符替换(/)
${变量名/旧的字串/新的字串} 将符合旧字串的第一个字串替换为新的字串
/
在字符串中搜索匹配的字符串并用新的内容替换旧内容,与#
##
%
%%
不同的是/
不强制从头尾字符开始匹配。
匹配变量中的 5678 并替换 8765
code5@code5-debian:~$ echo ${teststr/5678/8765}
123487659myvar@qq.com
code5@code5-debian:~$
6、字符替换(//)
${变量名//旧的字串/新的字串} 将符合旧字串的全部字串替换为新的字串
/
与//
都匹配并替换变量内容,但/
只匹配第一个符合的内容并替换 而//
会匹配所有符合的内容并替换
把所有 m 替换成 ? :使用 /
(只替换第一个m)
code5@code5-debian:~$ echo ${teststr/m/?}
123456789?yvar@qq.com
code5@code5-debian:~$
把所有 m 替换成 ? :使用 //
(替换了所有m)
# 注意是 /? 不是 //?
code5@code5-debian:~$ echo ${teststr//m/?}
123456789?yvar@qq.co?
code5@code5-debian:~$
网友评论