shell字符串截取

sed"s/\'/\'\'/g"a.txt>test.log

${varible##*string}从左向右截取最后一个string后的字符串

${varible#*string}从左向右截取第一个string后的字符串

${varible%%string*}从右向左截取最后一个string后的字符串

${varible%string*}从右向左截取第一个string后的字符串

“*”只是一个通配符可以不要

例子如下:

[xiangyu@localhost~]$a="finding"

[xiangyu@localhost~]$echo${a##*in}

g

[xiangyu@localhost~]$echo${a#*in}

ding

[xiangyu@localhost~]$echo${a%%in*}

f

[xiangyu@localhost~]$echo${a%in*}

find

好了,为了让这个字符串截取完整些,把另外些方法也一并贴出来吧!

一、Linuxshell截取字符变量的前8位,有方法如下:

1.exprsubstr“$a”18

2.echo$a|awk‘{printsubstr(,1,8)}’

3.echo$a|cut-c1-8

4.echo$

5.expr$a:‘\(.\\).*’

6.echo$a|ddbs=1count=82>/dev/null

二、按指定的字符串截取

上面带例子的是第一种方法。

还有一种方法:${varible:n1:n2}:截取变量varible从n1到n2之间的字符串。

可以根据特定字符偏移和长度,使用另一种形式的变量扩展,来选择特定子字符串。试着在bash中输入以下行:

$EXCLAIM=cowabunga

$echo${EXCLAIM:0:3}

cow

$echo${EXCLAIM:3:7}

abunga

这种形式的字符串截断非常简便,只需用冒号分开来指定起始字符和子字符串长度。

三、按照指定要求分割:

比如获取后缀名

ls-al|cut-d“.”-f2

相关推荐