每一种语言都有他独自的字符串操做方法,shell也同样,下面以以例子的方式,简单介绍经常使用方法。php
1,取得字符串长度html
string=abc12342341 //等号二边不要有空格 echo ${#string} //结果11 expr length $string //结果11 expr "$string" : ".*" //结果11 分号二边要有空格,这里的:根match的用法差很少
2,字符串所在位置shell
expr index $string '123' //结果4 字符串对应的下标是从0开始的
这个方法让我想起来了js的indexOf,各类语言对字符串的操做方法大方向都差很少,若是有语言基础的话,学习shell会很快的。函数
3,从字符串开头到子串的最大长度学习
expr match $string 'abc.*3' //结果9
我的以为这个函数的用处不大,为何要从开头开始呢。spa
4,字符串截取code
echo ${string:4} //2342341 从第4位开始截取后面全部字符串 echo ${string:3:3} //123 从第3位开始截取后面3位 echo ${string:3:6} //123423 从第3位开始截取后面6位 echo ${string: -4} //2341 :右边有空格 截取后4位 echo ${string:(-4)} //2341 同上 expr substr $string 3 3 //123 从第3位开始截取后面3位
上面的方法让我想起了,php的substr函数,后面截取的规则是同样的。htm
5,匹配显示内容blog
//例3中也有match和这里的match不一样,上面显示的是匹配字符的长度,而下面的是匹配的内容 expr match $string '\([a-c]*[0-9]*\)' //abc12342341 expr $string : '\([a-c]*[0-9]\)' //abc1 expr $string : '.*\([0-9][0-9][0-9]\)' //341 显示括号中匹配的内容
这里括号的用法,是否是根其余的括号用法有类似之处呢,ip
6,截取不匹配的内容
echo ${string#a*3} //42341 从$string左边开始,去掉最短匹配子串 echo ${string#c*3} //abc12342341 这样什么也没有匹配到 echo ${string#*c1*3} //42341 从$string左边开始,去掉最短匹配子串 echo ${string##a*3} //41 从$string左边开始,去掉最长匹配子串 echo ${string%3*1} //abc12342 从$string右边开始,去掉最短匹配子串 echo ${string%%3*1} //abc12 从$string右边开始,去掉最长匹配子串
这里要注意,必须从字符串的第一个字符开始,或者从最后一个开始,
7,匹配而且替换
echo ${string/23/bb} //abc1bb42341 替换一次 echo ${string//23/bb} //abc1bb4bb41 双斜杠替换全部匹配 echo ${string/#abc/bb} //bb12342341 #以什么开头来匹配,根php中的^有点像 echo ${string/%41/bb} //abc123423bb %以什么结尾来匹配,根php中的$有点像
转自: http://blog.51yip.com/shell/1080.html