上一章节讲解了为什么用${}引用变量,${}还有一个重要的功能,就是文本处理,单行文本基本上可以满足你所有需求。
2.1 获取字符串长度
2.2 字符串切片
格式:
${parameter:offset}
${parameter:offset:length}
截取从offset个字符开始,向后length个字符。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
截取hello字符串:
hello
截取wo字符:
wo
截取world!字符串:
world!
截取最后一个字符:
!
截取最后二个字符:
d!
截取从倒数第3个字符后的2个字符:
ld
|
2.3 替换字符串
格式:${parameter/pattern/string}
1
2
3
4
5
6
7
|
将第一个world字符串替换为WORLD:
hello WORLD world!
将全部world字符串替换为WORLD:
hello WORLD WORLD!
|
2.4 字符串截取
格式:
${parameter#word} # 删除匹配前缀
${parameter##word}
${parameter%word} # 删除匹配后缀
${parameter%%word}
# 去掉左边,最短匹配模式,##最长匹配模式。
% 去掉右边,最短匹配模式,%%最长匹配模式。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
以 // 为分隔符截取右边字符串:
www.baidu.com /baike/user .html
以/为分隔符截取右边字符串:
user.html
以 // 为分隔符截取左边字符串:
http:
以/为分隔符截取左边字符串:
http: //www .baidu.com /baike
以.为分隔符截取左边:
http: //www .baidu.com /baike/user
以.为分隔符截取右边:
html
|
# 去掉左边,从左边匹配第一个,##从右边匹配第一个。
% 去掉右边,从右边匹配第一个,%%从左边匹配第一个。
有*号情况下才这样。
2.5 变量状态赋值
${VAR:-string} 如果VAR变量为空则返回string
${VAR:+string} 如果VAR变量不为空则返回string
${VAR:=string} 如果VAR变量为空则重新赋值VAR变量值为string
${VAR:?string} 如果VAR变量为空则将string输出到stderr
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
如果变量为空就返回hello world!:
hello world!
如果变量不为空就返回hello world!:
hello world!
如果变量为空就重新赋值:
hello
hello
如果变量为空就将信息输出stderr:
- bash : VAR: value is null
|
${}主要用途大概就这么多了,另外还可以获取数组元素,在后面章节会讲到。
博客地址:http://lizhenliang.blog.51cto.com
QQ群:Shell/Python运维开发群 323779636
2.6 字符串颜色
再介绍下字符串输出颜色,有时候关键地方需要醒目,颜色是最好的方式:
字体颜色
|
字体背景颜色
|
显示方式
|
30:黑
31:红
32:绿
33:黄
34:蓝色
35:紫色
36:深绿
37:白色
|
40:黑
41:深红
42:绿
43:黄色
44:蓝色
45:紫色
46:深绿
47:白色
|
0:终端默认设置
1:高亮显示
4:下划线
5:闪烁
7:反白显示
8:隐藏
|
格式:
\033[1;31;40m # 1是显示方式,可选。31是字体颜色。40m是字体背景颜色。
\033[0m # 恢复终端默认颜色,即取消颜色设置。
|
示例:
1
2
3
4
5
6
7
8
9
10
11
12
13
|
#!/bin/bash
for i in {31..37}; do
echo -e "\033[$i;40mHello world!\033[0m"
done
for i in {41..47}; do
echo -e "\033[47;${i}mHello world!\033[0m"
done
for i in {1..8}; do
echo -e "\033[$i;31;40mHello world!\033[0m"
done
|

本文转自 李振良OK 51CTO博客,原文链接:http://blog.51cto.com/lizhenliang/1881836,如需转载请自行联系原作者