1. 取长度
1 | str= "abcd" |
2 | expr length $str # 4 |
3 | echo ${ #str} # 4 |
4 | expr "$str" : ".*" # 4 |
好像一般使用第二种
2. 查找子串的位置
1 | str= "abc" |
2 | expr index $str "a" # 1 |
3 | expr index $str "b" # 2 |
4 | expr index $str "x" # 0 |
5 | expr index $str "" # 0 |
3. 选取子串
1 | str= "abcdef" |
2 | expr substr "$str" 1 3 # 从第一个位置开始取3个字符, abc |
3 | expr substr "$str" 2 5 # 从第二个位置开始取5个字符, bcdef |
4 | expr substr "$str" 4 5 # 从第四个位置开始取5个字符, def |
5 |
6 | echo ${str:2} # 从第二个位置开始提取字符串, bcdef |
7 | echo ${str:2:3} # 从第二个位置开始提取3个字符, bcd |
8 | echo ${str:(-2)} # 从倒数第二个位置向左提取字符串, abcde |
9 | echo ${str:(-2):3} # 从倒数第二个位置向左提取6个字符, cde |
4. 截取子串
01 | str= "abbc,def,ghi,abcjkl" |
02 | echo ${str #a*c} # ,def,ghi,abcjkl 一个井号(#) 表示从左边截取掉最短的匹配 (这里把abbc字串去掉) |
03 | echo ${str ##a*c} # jkl, 两个井号(##) 表示从左边截取掉最长的匹配 (这里把abbc,def,ghi,abc字串去掉) |
04 | echo ${str #"a*c"} # 空,因为str中没有子串"a*c" |
05 | echo $[str ##"a*c"} # 空,同理 |
06 | echo ${str #d*f) # abbc,def,ghi,abcjkl, |
07 | echo ${str #*d*f} # ,ghi,abcjkl |
08 |
09 | echo ${str%a*l} # abbc,def,ghi 一个百分号(%)表示从右边截取最短的匹配 |
10 | echo ${str%%b*l} # a 两个百分号表示(%%)表示从右边截取最长的匹配 |
11 | echo ${str%a*c} # abbc,def,ghi,abcjkl |
可以这样记忆, 井号(#)通常用于表示一个数字,它是放在前面的;百分号(%)卸载数字的后面; 或者这样记忆,在键盘布局中,井号(#)总是位于百分号(%)的左边(即前面) :-)
5. 字符串替换
1 | str= "apple, tree, apple tree" |
2 | echo ${str/apple/APPLE} # 替换第一次出现的apple |
3 | echo ${str//apple/APPLE} # 替换所有apple |
4 |
5 | echo ${str/ #apple/APPLE} # 如果字符串str以apple开头,则用APPLE替换它 |
6 | echo ${str/%apple/APPLE} # 如果字符串str以apple结尾,则用APPLE替换它 |
6. 比较
1 | [[ "a.txt" == a* ]] # 逻辑真 (pattern matching) |
2 | [[ "a.txt" =~ .*\.txt ]] # 逻辑真 (regex matching) |
3 | [[ "abc" == "abc" ]] # 逻辑真 (string comparision) |
4 | [[ "11" < "2" ]] # 逻辑真 (string comparision), 按ascii值比较 |
7. 连接
1 | s1= "hello" |
2 | s2= "world" |
3 | echo ${s1}${s2} # 当然这样写 $s1$s2 也行,但最好加上大括号 |
8. 翻转
http://my.oschina.net/aiguozhe/blog/41557