在shell脚本中我们所有变量的存储形式都是字符串。所以对于字符串的截取来说就变得十分重要了。


而在shell脚本中,如果想要对一个字符串进行指定的截取,有多种方法可以来完成:
如下举例均用:STR="hello world my dear sister"

${STR#*char}表示从左开始删除第一个char左边的所有字符,截取右边的字符串

#!/bin/bashSTR="helloworldmydearsister"echo${STR}CUT=${STR#*}echo${CUT}

结果:



${STR##*char}表示从左开始删除最后一个char左边的所有字符,截取右边的字符串
将上例程序改为:

CUT=${STR##*/}

结果:


${STR%char*}表示从右开始删除第一个char右边的所有字符,截取左边的字符串

将上例程序改为:

CUT=${STR%/*}


同样*可以看做是通配符,表示匹配右边所有的字符删除,保留左边;

结果:


${STR%char*}表示从右开始删除最后一个char右边的所有字符,截取左边的字符串

将上例程序改为如下:

CUT=${STR%%/*}[objectObject]

结果:


${STR:N:M}表示从左边第N个字符开始截取M个字符,不包括第N个字符
将上例程序改为:

CUT=${STR:3:8}

表示从左边第3个字符开始截取后面的8个字符;如果N为0表示从第一个字符开始,但是包括第一个字符;

结果:



${STR:N}表示从左边第N个字符开始截取后面所有的字符,不包括第N个字符

将上面程序改为如下:

CUT=${STR:7}

表示从左边第7个字符开始取后面的所有字符;

结果:



${STR:0-N:M}表示从右边第N个字符开始截取M个字符,包括第N个字符


将上例程序改为:

CUT=${STR:0-7:3}


表示从右边开始数第7个字符开始,包括第七个字符本身,截取三个字符;

结果:

空格在行首的同时不输出。其他字符是输出的,大家可以下去试一试是否包含他本身



${STR:0-N}表示从右边第N个字符开始截取后面的所有字符,包括第N个字符

将上例程序改为:

CUT=${STR:0-7}

表示从右边开始数第7个字符开始截取后面的所有字符;

结果:

空格不输出。其他字符是输出的,大家可以下去试一试是否包含他本身



${STR}|cut-cN表示取从左边开始数的第N个字符

示例代码:

#!/bin/bashSTR="helloworldmydearsister"echo${STR}echo${STR}|cut-c7

表示截取从左边数第7个字符;

结果:




${STR}|cut-cN-表示截取从左边开始数的第N个字符往后的所有字符,包括第N个

更改如上程序:

echo${STR}|cut-c7-

表示从截取从左边第7个字符开始剩下的所有字符;

结果:



${STR}|cut-cN-M表示截取从左边开始数的第N个字符到第M个字符之间的所有字符,包括第N个字符,但是不包括第M个字符

将程序改为如下:

echo${STR}|cut-c2-7


表示截取从左边第2个字符到第7个字符之间的所有字符,包括第2个字符,不包括第7个字符;

结果:



${STR}|cut-c-N表示截取从左边开始数的第N个字符往前的所有字符,包括第N个字符

将程序改为如下:

echo${STR}|cut-c-7


表示从左边第7个字符开始数删除后面所有的字符,截取前面的字符;

结果:



exprsubstr"${STR}"NM表示从左边第N个字符开始往后截取M个字符

示例程序:

#!/bin/bashSTR="helloworldmydearsister"echo${STR}CUT=$(exprsubstr"${STR}"35)echo$CUT


因为expr是命令,所以上面的$()为命令替换,表示截取从左边第3个字符开始往后截取5个字符;

结果: