字符串截取及切割 一

知识共享许可协议 Creative Commons

问题
使用Shell完成各种Linux运维任务时,一旦涉及到判断、条件测试等相关操作时,往往需要对相关的命令输出进行过滤,提取出符合要求的字符串。
本案例要求熟悉字符串的常见处理操作,完成以下任务练习:
参考PPT示范操作,完成子串截取、替换等操作
根据课上的批量改名脚本,编写改进版renfilex.sh:能够批量修改当前目录下所有文件的扩展名,修改前/后的扩展名通过位置参数$1、$2提供
方案
子串截取的三种用法:
v a r : : e x p r s u b s t r " {var:起始位置:长度} expr substr " var" 起始位置 长度
echo v a r c u t b d i r n a m e " " b a s e n a m e " " var | cut -b 起始位置-结束位置 路径分割: 取目录位置:dirname "字符串" 取文档的基本名称:basename "字符串" 子串替换的两种用法: 只替换第一个匹配结果: {var/old/new}
替换全部匹配结果: v a r / / o l d / n e w {var//old/new} 字符串掐头去尾: 从左向右,最短匹配删除: {变量名#关键词}
从左向右,最长匹配删除:KaTeX parse error: Expected '}', got '#' at position 5: {变量名#̲#*关键词} 从右向左,最短匹…{变量名%关键词
}
从右向左,最长匹配删除:${变量名%%关键词
}
步骤
实现此案例需要按照如下步骤进行。
*

步骤一:字符串的截取

1)方法一,使用 {}表达式 格式: {var:起始位置:长度}
定义一个变量SCHOOL,并确认其字符串长度:

[root@svr5 ~]# SCHOOL="Tarena IT Group."
[root@svr5 ~]# echo ${#SCHOOL}
16  										//包括16个字符(含空格)

使用${}截取时,起始位置可以省略,省略时从第一个字符开始截。比如,以下操作都可以从左侧开始截取前6个字符:

[root@svr5 ~]# echo ${SCHOOL::6}
Tarena
或者
[root@svr5 ~]# echo ${SCHOOL:0:6}
Tarena

使用${}方式截取字符串时,起始位置是从0开始的(和数组下标编号类似) 。
因此,如果从起始位置1开始截取6个字符,那就变成这个样子了:

[root@svr5 ~]# echo ${SCHOOL:1:6}
arena 							//最后的空格未显示出来,实际为“arena ”

应用示例:提取文件/etc/fstab的MD5SUM校验和字串,排除无关文本。相关操作及结果如下所示:

[root@svr5 ~]# md5sum /etc/fstab  				//直接查看MD5SUM校验值
eef0254e6049a411dc30db864c0ee6ea  /etc/fstab
[root@svr5 ~]# MD5STR=$(md5sum /etc/fstab) 		//保存到变量
[root@svr5 ~]# echo ${MD5STR::32}  		//截取前32个字符(MD5值的固定长度)
eef0254e6049a411dc30db864c0ee6ea

2)方法二,使用 expr substr
格式:expr substr “$var” 起始位置 长度
还以前面的SCHOOL变量为例,确认原始值:

[root@svr5 ~]# echo $SCHOOL
Tarena IT Group.
[root@svr5 ~]# echo ${#SCHOOL}
16

使用expr substr截取字符串时,起始编号从1开始,这个要注意与${}相区分。
从左侧截取SCHOOL变量的前6个字符:

[root@svr5 ~]# expr substr "$SCHOOL" 1 6
Tarena

这里注意,因为SCHOOL变量的值里含有空格,所以应该加双引号进行调用,否则是会报错的:

[root@svr5 ~]# expr substr $SCHOOL 1 6
expr: 语法错误

从左侧截取SCHOOL变量的第11-16个字符:

[root@svr5 ~]# expr substr "$SCHOOL" 11 16
Group.

应用示例:还是提取文件/etc/fstab的MD5SUM校验和字串,排除无关文本。若采用expr substr,则相关操作及结果如下所示:

[root@svr5 ~]# md5sum /etc/fstab  				//确认MD5SUM校验值
eef0254e6049a411dc30db864c0ee6ea  /etc/fstab
[root@svr5 ~]# MD5STR=$(md5sum /etc/fstab) 		//保存到变量
[root@svr5 ~]# expr substr "$MD5STR" 1 32  		//截取前32个字符
eef0254e6049a411dc30db864c0ee6ea

3)方式三,使用cut分割工具
格式:echo $var | cut -b 起始位置-结束位置
选项 -b 表示按字节截取字符,其中起始位置、结束位置都可以省略。当省略起始位置时,视为从第1个字符开始(编号也是从1开始,与expr类似),当省略结束位置时,视为截取到最后。
还以前面的SCHOOL变量为例,确认原始值:

[root@svr5 ~]# echo $SCHOOL
Tarena IT Group.
[root@svr5 ~]# echo ${#SCHOOL}
16

从左侧截取前6个字符,可执行以下操作:

[root@svr5 ~]# echo $SCHOOL | cut -b 1-6
Tarena

或者

[root@svr5 ~]# echo $SCHOOL | cut -b -6
Tarena

截取第11-16个字符:

[root@svr5 ~]# echo $SCHOOL | cut -b 11-16
Group.

从第8个字符截取到末尾:

[root@svr5 ~]# echo $SCHOOL | cut -b 8-
IT Group.

只截取单个字符,比如第9个字符:

[root@svr5 ~]# echo $SCHOOL | cut -b 9
T

如果起始位置、结束位置同时省略,那就和直接echo变量值没啥区别了:

[root@svr5 ~]# echo $SCHOOL | cut -b -
Tarena IT Group.

应用示例:还是提取文件/etc/fstab的MD5SUM校验和字串,排除无关文本。若采用cut工具,可以直接通过管道处理,相关操作及结果如下所示:

[root@svr5 ~]# md5sum /etc/fstab  				//确认MD5SUM校验值
eef0254e6049a411dc30db864c0ee6ea  /etc/fstab
[root@svr5 ~]# md5sum /etc/fstab | cut -b -32	//截取前32个字符
eef0254e6049a411dc30db864c0ee6ea

猜你喜欢

转载自blog.csdn.net/weixin_44774638/article/details/91851043