字符串的3种格式
- 单引号方式
- 双引号方式, 推荐
- 不用引号方式
[root@node1 ~] name=abc
[root@node1 ~] name2='abc'
[root@node1 ~] name3="abc" # 推荐
[root@node1 ~]
3种格式的区别
- 无引号: 会识别${变量},但是中间不能有空格,有空格,命令会被切割
[root@node1 ~] name=aa bb cc
-bash: bb: 未找到命令
- 单引号: 所有字符都会都会被原样输出,${变量}不会被识别
[root@node1 ~] name2='abc'
[root@node1 ~] echo $name2
abc
[root@node1 ~] echo '名字2是: ${name2}'
名字2是: ${name2}
- 双引号: 可以识别${变量},中间可以有空格
[root@node1 ~] name2='abc'
[root@node1 ~] echo $name2
abc
[root@node1 ~] echo "名字2是: ${name2}"
名字2是: abc
获取字符串的长度
${#字符串变量名}
[root@node1 ~] echo $name
abc
[root@node1 ~] echo ${#name}
3
字符串拼接
- 无符号拼接
- 双引号拼接
[root@node1 ~] var1=abc
[root@node1 ~] var2=def
[root@node1 ~] echo $var1$var2 #无符号拼接
abcdef
[root@node1 ~] echo ${var1}${var2} #无符号拼接
abcdef
[root@node1 ~] echo "${var1}${var2}" #双引号拼接
abcdef
[root@node1 ~] echo ${var1}"&"${var2} #混合拼接
abc&def
[root@node1 ~] echo ${var1}'&'${var2} #混合拼接
abc&def
字符串截取语法
格式 | 说明 |
---|---|
${变量名:start:length} | 从 string 字符串的左边第 start 个字符开始, 向右截取 length 个字符。 |
${变量名:start} | 从 string 字符串的左边第 start 个字符开始截取,直到最后。 |
${变量名:0-start:length} | 从 string 字符串的右边第 start 个字符开始, 向右截取 length 个字符。 |
${变量名:0-start} | 从 string 字符串的右边第 start 个字符开始截取,直到最后。 |
${变量名#*chars} | 从 string 字符串第一次出现 _chars 的位置开始, 截取 _chars 右边的所有字符。 |
${变量名##*chars} | 从 string 字符串最后一次出现 _chars 的位置开始, 截取 _chars 右边的所有字符。 |
${变量名%chars*} | 从 string 字符串最后第一次出现 chars_ 的位置开始, 截取 chars_ 左边的所有字符。 |
${变量名%%chars*} | 从 string 字符串第一次出现 chars_ 的位置开始, 截取 chars_ 左边的所有字符 |
[root@node1 ~] var1=abcdefg
[root@node1 ~] echo $var1:2:4 #错误表达式
abcdefg:2:4
[root@node1 ~] echo ${var1:2:4}
cdef
[root@node1 ~] echo ${var1:2}
cdefg
[root@node1 ~] echo ${var1:0-2:2} #0-start是固定写法
fg
[root@node1 ~] echo ${var1:-2:2} #不能直接写成-start,会失效,直接显示全部字符串
abcdefg
[root@node1 ~] echo ${var1:0-2}
fg
[root@node1 ~] var2=aabbccdd
[root@node1 ~] echo ${var2#*c}
cdd
[root@node1 ~] echo ${var2##*c}
dd
[root@node1 ~] echo ${var2%c*}
aabbc
[root@node1 ~] echo ${var2%%c*}
aabb
[root@node1 ~]