字符串截取及切割 字符串初值的处理 expect预期交互 使用正则表达式

1 案例1:字符串截取及切割

1.1 问题

使用Shell完成各种Linux运维任务时,一旦涉及到判断、条件测试等相关操作时,往往需要对相关的命令输出进行过滤,提取出符合要求的字符串。

本案例要求熟悉字符串的常见处理操作,完成以下任务练习:

  • 参考PPT示范操作,完成子串截取、替换等操作
  • 根据课上的批量改名脚本,编写改进版renfilex.sh:能够批量修改当前目录下所有文件的扩展名,修改前/后的扩展名通过位置参数$1、$2提供

1.2 方案

子串截取的三种用法:

  • ${变量名:起始位置:长度}
  • expr substr "$变量名" 起始位置 长度
  • echo $变量名 | cut -b 起始位置-结束位置

子串替换的两种用法:

  • 只替换第一个匹配结果:${变量名/old/new}
  • 替换全部匹配结果:${变量名//old/new}

字符串掐头去尾:

  • 从左向右,最短匹配删除:${变量名#*关键词}
  • 从左向右,最长匹配删除:${变量名##*关键词}
  • 从右向左,最短匹配删除:${变量名%关键词*}
  • 从右向左,最长匹配删除:${变量名%%关键词*}

1.3 步骤

实现此案例需要按照如下步骤进行。

步骤一:字符串的截取

1)方法一,使用 ${}表达式

格式:${变量名:起始位置:长度}

使用${}方式截取字符串时,起始位置是从0开始的。

定义一个变量phone,并确认其字符串长度:

  1. [root@svr5 ~]# phone="13788768897"
  2. [root@svr5 ~]# echo ${ #phone}
  3. 11                                         //包括11个字符

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

 
  
  1. [root@svr5 ~]# echo ${ phone:0:6}
  2. 137887

或者

  1. [root@svr5 ~]# echo ${ phone::6}
  2. 137887

因此,如果从起始位置1开始截取6个字符,那就变成这个样子了:

 
  
  1. [root@svr5 ~]# echo ${ phone:1:6}
  2. 378876

2)方法二,使用 expr substr

格式:expr substr "$变量名" 起始位置 长度

还以前面的phone变量为例,确认原始值:

  1. [root@svr5 ~]# echo $phone
  2. 13788768897

使用expr substr截取字符串时,起始编号从1开始,这个要注意与${}相区分。

从左侧截取phone变量的前6个字符:

 
  
  1. [root@svr5 ~]# expr substr "$phone" 1 6
  2. 137887

从左侧截取phone变量,从第9个字符开始,截取3个字符:

  1. [root@svr5 ~]# expr substr "$phone" 9 3
  2. 897

3)方式三,使用cut分割工具

格式:echo $变量名 | cut -b 起始位置-结束位置

选项 -b 表示按字节截取字符,其中起始位置、结束位置都可以省略。当省略起始位置时,视为从第1个字符开始(编号也是从1开始,与expr类似),当省略结束位置时,视为截取到最后。

还以前面的Phone变量为例,确认原始值:

 
  
  1. [root@svr5 ~]# echo $phone
  2. 13788768897

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

  1. [root@svr5 ~]# echo $phone | cut -b 1-6
  2. 137887

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

 
  
  1. [root@svr5 ~]# echo $phone | cut -b 8-
  2. 8897

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

  1. [root@svr5 ~]# echo $phone | cut -b 9
  2. 8

截取不连续的字符,比如第3、5、8个字符:

 
  
  1. [root@svr5 ~]# echo $phone | cut -b 3,5,8
  2. 788

4)一个随机密码的案例

版本1:

  1. [root@svr5 ~]# vim rand.sh
  2. #!/bin/bash
  3. x=abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789
  4. //所有密码的可能性是26+26+10=62(0-61是62个数字)
  5. num=$[RANDOM%62]
  6. pass=${ x:num:1}

版本2:

 
  
  1. [root@svr5 ~]# vim rand.sh
  2. #!/bin/bash
  3. x=abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789
  4. //所有密码的可能性是26+26+10=62(0-61是62个数字)
  5. pass=''
  6. for i in { 1..8}
  7. do
  8. num=$[RANDOM%62]
  9. tmp=${ x:num:1}
  10. pass=${ pass}$tmp
  11. done
  12. echo $pass

步骤二:字符串的替换

1)只替换第1个子串

格式:${变量名/old/new}

还以前面的phone变量为例,确认原始值:

  1. [root@svr5 ~]# echo $phone
  2. 13788768897

将字符串中的第1个8替换为X:

 
  
  1. [root@svr5 ~]# echo ${ phone/8/X}
  2. 137X8768897

2)替换全部子串

格式:${变量名//old/new}

将phone字符串中的所有8都替换为X:

  1. [root@svr5 ~]# echo ${ phone//8/X}
  2. 137XX76XX97

步骤三:字符串的匹配删除

以处理系统默认的账户信息为例,定义变量A:

 
  
  1. [root@svr5 ~]# A=`head -1 /etc/passwd`
  2. [root@svr5 ~]# echo $A
  3. root:x:0:0:root:/root:/bin/bash

1)从左向右,最短匹配删除

格式:${变量名#*关键词}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值