获取字符串长度
${#varname}
[root@localhost ~]# var=123456
[root@localhost ~]# echo ${#var}
6
字符串切片
${var:offset}
${var:offset:length}
截取从offset个字符开始,向后length个字符
[root@localhost ~]# echo ${var:0:2}
12
[root@localhost ~]# echo ${var:2:3}
345
截取最后一个字符:
[root@localhost ~]# echo ${var:(-1)}
6
截取最后三个字符:
[root@localhost ~]# echo ${var:(-3)}
456
截取从倒数第三个字符后的两个字符:
[root@localhost ~]# echo ${var:(-3):2}
45
注意字符的顺序是从零开始的
替换字符串
格式:${varname/pattern/string}表示匹配第一个字符
[root@localhost ~]# animal=\'black dog\'
[root@localhost ~]# echo ${animal/black/green}
green dog
*pattern可以使用正则表达式
[root@localhost ~]# char=123aaabbbccc
[root@localhost ~]# echo ${char/a*/4}
1234
${varname/pattern/string/}表示匹配所有字符
字符串截取
格式:
${varname#word} 表示删除匹配前缀
${varname##word}
${varname%word} 表示删除匹配后缀
${varname%%word}
% 去掉右边, 为最短匹配模式, %% 最长匹配模式
# 去掉左边,最短匹配模式,## 最长匹配模式
[root@localhost ~]# url="https://www.cnblogs.com/hzdwwzz"
[root@localhost ~]# echo ${url#*//}
www.cnblogs.com/hzdwwzz
以//为分隔符去除字符串
[root@localhost ~]# echo ${url##*/}
hzdwwzz
以/为分隔符去除所有前缀
[root@localhost ~]# echo ${url%%//*}
https:
[root@localhost ~]# echo ${url%/*}
https://www.cnblogs.com
变量状态赋值
${VAR:-string} 如果 VAR 变量为空则返回 string
${VAR:+string} 如果 VAR 变量不为空则返回 string
${VAR:=string} 如果 VAR 变量为空则重新赋值 VAR 变量值为 string
${VAR:?string} 如果 VAR 变量为空则将 string 输出到 stderr