Shell字符串截取(非常详细)

 

Shell 截取字符串通常有两种方式:从指定位置开始截取和从指定字符(子字符串)开始截取。

从指定位置开始截取

这种方式需要两个参数:除了指定起始位置,还需要截取长度,才能最终确定要截取的字符串。

既然需要指定起始位置,那么就涉及到计数方向的问题,到底是从字符串左边开始计数,还是从字符串右边开始计数。答案是 Shell 同时支持两种计数方式。

1) 从字符串左边开始计数

如果想从字符串的左边开始计数,那么截取字符串的具体格式如下:

${string: start :length}

其中,string 是要截取的字符串,start 是起始位置(从左边开始,从 0 开始计数),length 是要截取的长度(省略的话表示直到字符串的末尾)。

例如:

 
  1. url="c.biancheng.net"
  2. echo ${url: 2: 9}

结果为biancheng

再如:

 
  1. url="c.biancheng.net"
  2. echo ${url: 2} #省略 length,截取到字符串末尾

结果为biancheng.net

2) 从右边开始计数

如果想从字符串的右边开始计数,那么截取字符串的具体格式如下:

${string: 0-start :length}

同第 1) 种格式相比,第 2) 种格式仅仅多了0-,这是固定的写法,专门用来表示从字符串右边开始计数。

这里需要强调两点:

  • 从左边开始计数时,起始数字是 0(这符合程序员思维);从右边开始计数时,起始数字是 1(这符合常人思维)。计数方向不同,起始数字也不同。
  • 不管从哪边开始计数,截取方向都是从左到右。


例如:

 
  1. url="c.biancheng.net"
  2. echo ${url: 0-13: 9}

结果为biancheng。从右边数,b是第 13 个字符。

再如:

 
  1. url="c.biancheng.net"
  2. echo ${url: 0-13} #省略 length,直接截取到字符串末尾

结果为biancheng.net

从指定字符(子字符串)开始截取

这种截取方式无法指定字符串长度,只能从指定字符(子字符串)截取到字符串末尾。Shell 可以截取指定字符(子字符串)右边的所有字符,也可以截取左边的所有字符。

1) 使用 # 号截取右边字符

使用#号可以截取指定字符(或者子字符串)右边的所有字符,具体格式如下:

${string#*chars}

其中,string 表示要截取的字符,chars 是指定的字符(或者子字符串),*是通配符的一种,表示任意长度的字符串。*chars连起来使用的意思是:忽略左边的所有字符,直到遇见 chars(chars 不会被截取)。

请看下面的例子:

 
  1. url="http://c.biancheng.net/index.html"
  2. echo ${url#*:}

结果为//c.biancheng.net/index.html

以下写法也可以得到同样的结果:

 
  1. echo ${url#*p:}
  2. echo ${url#*ttp:}


如果不需要忽略 chars 左边的字符,那么也可以不写*,例如:

 
  1. url="http://c.biancheng.net/index.html"
  2. echo ${url#http://}

结果为c.biancheng.net/index.html

注意,以上写法遇到第一个匹配的字符(子字符串)就结束了。例如:

 
  1. url="http://c.biancheng.net/index.html"
  2. echo ${url#*/}

结果为/c.biancheng.net/index.html。url 字符串中有三个/,输出结果表明,Shell 遇到第一个/就匹配结束了。

如果希望直到最后一个指定字符(子字符串)再匹配结束,那么可以使用##,具体格式为:

${string##*chars}

请看下面的例子:

 
  1. #!/bin/bash
  2.  
  3. url="http://c.biancheng.net/index.html"
  4. echo ${url#*/} #结果为 /c.biancheng.net/index.html
  5. echo ${url##*/} #结果为 index.html
  6.  
  7. str="---aa+++aa@@@"
  8. echo ${str#*aa} #结果为 +++aa@@@
  9. echo ${str##*aa} #结果为 @@@

2) 使用 % 截取左边字符

使用%号可以截取指定字符(或者子字符串)左边的所有字符,具体格式如下:

${string%chars*}

请注意*的位置,因为要截取 chars 左边的字符,而忽略 chars 右边的字符,所以*应该位于 chars 的右侧。其他方面%#的用法相同,这里不再赘述,仅举例说明:

 
  1. #!/bin/bash
  2.  
  3. url="http://c.biancheng.net/index.html"
  4. echo ${url%/*} #结果为 http://c.biancheng.net
  5. echo ${url%%/*} #结果为 http:
  6.  
  7. str="---aa+++aa@@@"
  8. echo ${str%aa*} #结果为 ---aa+++
  9. echo ${str%%aa*} #结果为 ---

汇总

最后,我们对以上 8 种格式做一个汇总,请看下表:

格式说明
${string: start :length}从 string 字符串的左边第 start 个字符开始,向右截取 length 个字符。
${string: start}从 string 字符串的左边第 start 个字符开始截取,直到最后。
${string: 0-start :length}从 string 字符串的右边第 start 个字符开始,向右截取 length 个字符。
${string: 0-start}从 string 字符串的右边第 start 个字符开始截取,直到最后。
${string#*chars}从 string 字符串第一次出现 *chars 的位置开始,截取 *chars 右边的所有字符。
${string##*chars}从 string 字符串最后一次出现 *chars 的位置开始,截取 *chars 右边的所有字符。
${string%*chars}从 string 字符串第一次出现 *chars 的位置开始,截取 *chars 左边的所有字符。
${string%%*chars}从 string 字符串最后一次出现 *chars 的位置开始,截取 *chars 左边的所有字符。
### 回答1: 可以使用 `cut` 命令来截取字符串。例如: ``` $ echo "hello world" | cut -c 1-5 hello ``` 该命令表示将字符串 "hello world" 截取前 5 个字符,即 "hello"。 也可以使用 `sed` 命令来截取字符串。例如: ``` $ echo "hello world" | sed 's/\(^.\{5\}\).*/\1/' hello ``` 该命令表示将字符串 "hello world" 从开头截取 5 个字符,即 "hello"。 还可以使用 `awk` 命令来截取字符串。例如: ``` $ echo "hello world" | awk '{print substr($0,1,5)}' hello ``` 该命令表示将字符串 "hello world" 从1开始截取5个字符,即 "hello"。 ### 回答2: Shell 是一种命令行解释器(或者称为 shell 解释器),常用语法是通过键盘输入命令,然后由解释器执行操作。 在 Shell 中,有时候需要对字符串进行截取或者分割,以获取需要的部分数据,这就需要使用字符串截取操作。 字符串截取操作最基本的两种方式是: - 使用 `${string:position:length}` 的方式进行截取; - 使用 `${string#substring}` 或 `${string##substring}` 的方式进行截取。 其中,第一种方式可以根据位置和长度截取需要的子串,例如: ```bash # 获取 "hello world" 字符串中的前 5 个字符 echo ${"hello world":0:5} # 获取 "hello world" 字符串中的后 5 个字符 echo ${"hello world":(-5)} ``` 第二种方式则是根据子串进行截取,其中 `${string#substring}` 是从字符串的开头删除最短的匹配,`${string##substring}` 则是从字符串的开头删除最长的匹配。例如: ```bash # 从 "hello world" 中删除 hello,只剩下 world echo ${"hello world"#"hello "} # 从 "hello world" 中删除 hello,只剩下 world echo ${"hello world"##"hello "} ``` 以上就是 Shell 中处理字符串的两种基本截取方式。当然,除此之外,还有很多其他的字符串处理方法,例如使用 sed 等工具,可以更加灵活地处理字符串。 ### 回答3: 在Shell截取字符串是一项十分常用的技能,我们可以使用内置函数来进行字符串的截取,包括字符切割和正则表达式匹配。下面将具体介绍Shell中常用的字符串截取方法。 1. 字符切割 使用字符切割是最简单的字符串截取方法,在Shell中,我们可以使用“${变量名/模式/替换}”的形式来实现。具体方法如下: 例如,我们有一个字符串“string=hello,world”,要截取其中的“world”,可以使用以下命令: ``` echo ${string#*,} ``` 在这里,“#”号表示从左边开始删除第一个匹配的“,”号及其前面的所有字符,结果为“world”。 2. 正则表达式匹配 正则表达式匹配适用于需要对字符串进行更复杂的匹配操作,比如需要截取一些特定的字符或字符串。在Shell中,使用“=~”符号来进行正则表达式匹配,具体方法如下: 例如,我们有一个字符串“string=hello world”,要截取其中的“hello”,可以使用以下命令: ``` regexp='^([a-z]+)' [[ $string =~ $regexp ]] && echo ${BASH_REMATCH[1]} ``` 在这里,我们将正则表达式“^([a-z]+)”赋值给一个变量“regexp”,表示以小写字母开头的字符串,然后通过=~符号将字符串和正则表达式进行匹配。如果匹配成功,则BASH_REMATCH数组会按顺序存储匹配的结果,我们可以通过数组下标来获取具体的匹配结果。在这里,BASH_REMATCH[0]表示整个匹配结果,“hello”,BASH_REMATCH[1]表示第一个捕获分组的匹配结果,“hello”。 总之,截取字符串Shell中常用的操作之一,通过掌握上述的方法,可以方便地对字符串进行截取和处理。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值