Shell字符串截取(非常详细)
Shell 截取字符串通常有两种方式:从指定位置开始截取和从指定字符(子字符串)开始截取。
从指定位置开始截取
这种方式需要两个参数:除了指定起始位置,还需要截取长度,才能最终确定要截取的字符串。既然需要指定起始位置,那么就涉及到计数方向的问题,到底是从字符串左边开始计数,还是从字符串右边开始计数。答案是 Shell 同时支持两种计数方式。
1) 从字符串左边开始计数
如果想从字符串的左边开始计数,那么截取字符串的具体格式如下:
${string: start :length}
其中,string 是要截取的字符串,start 是起始位置(从左边开始,从 0 开始计数),length 是要截取的长度(省略的话表示直到字符串的末尾)。例如:
url="c.biancheng网站站点" rel="nofollow" />
url="c.biancheng网站站点" rel="nofollow" />
同第 1) 种格式相比,第 2) 种格式仅仅多了${string: 0-start :length}
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" />