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

一、从指定位置开始截取

1)从字符串的左边开始截取(下标计数从0开始)

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

${string: start :length}

其中,string 是要截取的字符串,start 是起始位置(从左边开始,从 0 开始计数,第一个字符为0,第二个字符为1,依次类推),length 是要截取的长度(省略的话表示直到字符串的末尾)。

例如:

url="www.baidu.com"
echo ${url:4:5}
结果为:baidu 从下标为4开始,截取5个字符。

再如:

url="a.github.com"
echo ${url:2}  #省略length参数,表示截取到字符串末尾
结果为:github.com

 2)从字符串右边开始计数

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

${string: 0-start :length}

 

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

这里需要强调两点:

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

 例如:

url="www.baidu.com"
echo ${url: 0-9:5}
结果为:baidu 从右边数,b是第9个字符

 

 再如:

url="www.baidu.com"
echo ${url:0-9}  #省略 length,直接截取到字符串末尾
结果为:baidu.com

 

 

二、从指定字符开始截取

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

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

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

${string#*chars}

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

请看下面的例子:

url="http://www.baidu.com/index.html"
echo ${url#*:}
结果为://www.baidu.com/index.html *表示匹配任意字符直到匹配到:停止,最后截取:右侧的所有字符串

 

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

echo ${url#*p:}   
echo ${url#*ttp:}
以上的写法得到的结果是相同的。

 

如果不需要模糊匹配 chars 左边的字符,那么也可以不写*,可以写全匹配,例如:

url="https://www.baidu.com/index.html"
echo ${url#https://}
结果为:www.baidu.com/index.html 从左到右全匹配https://

 

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

url="http://www.baidu.com/index.html"
echo ${url#*/}
结果为:/www.baidu.com/index.html url 字符串中有三个/,输出结果表明,Shell 遇到第一个/就匹配结束了。

 

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

${string##*chars}

请看下面的例子:

#!/bin/bash
url="http://www.baidu.com/index.html"
echo ${url#*/}    #结果为 /www.baidu.com/index.html
echo ${url##*/}   #结果为 index.html    从左到右匹配到最后一个/后结束匹配。               

 

2) 使用 % 截取左边字符

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

${string%chars*}

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

#!/bin/bash
url="http://www.baidu.com/index.html"
echo ${url%/*}  #结果为 http://www.baidu.com
echo ${url%%/*}  #结果为 http:   

 

汇总

格式说明
${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 左边的所有字符。

posted @ 2023-01-03 15:36  粉色纽扣  阅读(2342)  评论(1编辑  收藏  举报