ITPub博客

首页 > Linux操作系统 > Linux操作系统 > shell中的一个类似substr的用法

shell中的一个类似substr的用法

原创 Linux操作系统 作者:regonly1 时间:2009-04-09 15:20:04 0 删除 编辑

原来在shell中如果遇到要截取字符串的情况,就调用awk中的substr来实现。
今天了解到一种新的方法,原来shell中本身就支持这种用法。
如,有一字符串"12345678",现在要截取第三个到第六个字符的字符串区间。
则可以:
[lyon@bss-test6 ~]$ export str="123456789"
[lyon@bss-test6 ~]$ echo ${str:3:(6-3)}
456
[lyon@bss-test6 ~]$ unset str
从以上第二个表达式可以看出这个用法,即:${str:3:(6-3)}
可以归纳为:${str:begin:len},且支持表达式,如:6-3。

补充一下从网上找到一些其他的用法:

shell字符截取的问题:
一、Linux shell 截取字符变量的前8位,有方法如下:
1.expr substr “$a” 1 8
2.echo $a|awk ‘{print substr(,1,8)}’
3.echo $a|cut -c1-8
4.echo $
5.expr $a : ‘\(.\\).*’
6.echo $a|dd bs=1 count=8 2>/dev/null

二、按指定的字符截取
1、第一种方法:
${varible##*string} 从左向右截取最后一个string后的字符
${varible#*string}从左向右截取第一个string后的字符
${varible%%string*}从右向左截取最后一个string后的字符
${varible%string*}从右向左截取第一个string后的字符
“*”只是一个通配符可以不要

例子:
$ MYVAR=foodforthought.jpg
$ echo ${MYVAR##*fo}
rthought.jpg
$ echo ${MYVAR#*fo}
odforthought.jpg

2、第二种方法:${varible:n1:n2}:截取变量varible从n1到n2之间的字符

可以根据特定字符偏移和长度,使用另一种形式的变量扩展,来选择特定子字符。试着在 bash 中输入以下行:
$ EXCLAIM=cowabunga
$ echo ${EXCLAIM:0:3}
cow
$ echo ${EXCLAIM:3:7}
abunga

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

三、按照指定要求分割:
比如获取后缀名
ls -al | cut -d “.” -f2

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/12932950/viewspace-586873/,如需转载,请注明出处,否则将追究法律责任。

请登录后发表评论 登录
全部评论

注册时间:2008-05-10

  • 博文量
    257
  • 访问量
    1045442