每一种语言都有他独自的字符串操作方法,shell也一样,下面以以例子的方式,简单介绍常用方法。
1,取得字符串长度
-
string=abc12342341 //等号二边不要有空格 echo ${#string} //结果11 expr length $string //结果11 expr "$string" : ".*" //结果11 分号二边要有空格,这里的:根match的用法差不多
2,字符串所在位置
-
expr index $string ‘123‘ //结果4 字符串对应的下标是从0开始的
这个方法让我想起来了js的indexOf,各种语言对字符串的操作方法大方向都差不多,如果有语言基础的话,学习shell会很快的。
3,从字符串开头到子串的最大长度
-
expr match $string ‘abc.*3‘ //结果9
个人觉得这个函数的用处不大,为什么要从开头开始呢。
4,字符串截取
-
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函数,后面截取的规则是一样的。
5,匹配显示内容
-
//例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 显示括号中匹配的内容
这里括号的用法,是不是根其他的括号用法有相似之处呢,
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
时间: 2024-10-05 23:25:35