每一種語言都有他獨自的字符串操做方法,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