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

1年前 (2024-04-27)

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

从指定位置开始截取

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

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

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

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

${string: start :length}

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

例如:

url="c.biancheng网站站点" rel="nofollow" />

url="c.biancheng网站站点" rel="nofollow" />

${string: 0-start :length}

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

这里需要强调两点:

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

  • 不管从哪边开始计数,截取方向都是从左到右。


例如:

url="c.biancheng网站站点" rel="nofollow" />

url="c.biancheng网站站点" rel="nofollow" />

${string#*chars}

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

请看下面的例子:

url="http://c.biancheng网站站点" rel="nofollow" />

echo ${url#*p:}

echo ${url#*ttp:}


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

url="http://c.biancheng网站站点" rel="nofollow" />

url="http://c.biancheng网站站点" rel="nofollow" />

${string##*chars}

请看下面的例子:

#!/bin/bash

url="http://c.biancheng网站站点" rel="nofollow" />

${string%chars*}

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

#!/bin/bash

url="http://c.biancheng网站站点" rel="nofollow" />