裝載自:http://my.oschina.net/aiguozhe/blog/41557
1. 取長度
str="abcd" expr length $str # 4 echo ${#str} # 4 expr "$str" : ".*" # 4好像一般使用第二種
2. 查找子串的位置
str="abc" expr index $str "a" # 1 expr index $str "b" # 2 expr index $str "x" # 0 expr index $str "" # 0
3. 選取子串
str="abcdef" expr substr "$str" 1 3 # 從第一個位置開始取3個字符, abc expr substr "$str" 2 5 # 從第二個位置開始取5個字符, bcdef expr substr "$str" 4 5 # 從第四個位置開始取5個字符, def echo ${str:2} # 從第二個位置開始提取字符串, bcdef echo ${str:2:3} # 從第二個位置開始提取3個字符, bcd echo ${str:(-6):5} # 從倒數第二個位置向左提取字符串, abcde echo ${str:(-4):3} # 從倒數第二個位置向左提取6個字符, cde
4. 截取子串
str="abbc,def,ghi,abcjkl" echo ${str#a*c} # 輸出,def,ghi,abcjkl 一個井號(#) 表示從左邊截取掉最短的匹配 (這里把abbc字串去掉) echo ${str##a*c} # 輸出jkl, 兩個井號(##) 表示從左邊截取掉最長的匹配 (這里把abbc,def,ghi,abc字串去掉) echo ${str#"a*c"} # 輸出abbc,def,ghi,abcjkl 因為str中沒有"a*c"子串 echo ${str##"a*c"} # 輸出abbc,def,ghi,abcjkl 同理 echo ${str#*a*c*} # 空 echo ${str##*a*c*} # 空 echo ${str#d*f) # 輸出abbc,def,ghi,abcjkl, echo ${str#*d*f} # 輸出,ghi,abcjkl echo ${str%a*l} # abbc,def,ghi 一個百分號(%)表示從右邊截取最短的匹配 echo ${str%%b*l} # a 兩個百分號表示(%%)表示從右邊截取最長的匹配 echo ${str%a*c} # abbc,def,ghi,abcjkl
可以這樣記憶, 井號(#)通常用於表示一個數字,它是放在前面的;百分號(%)卸載數字的后面; 或者這樣記憶,在鍵盤布局中,井號(#)總是位於百分號(%)的左邊(即前面) :-)
5. 字符串替換
str="apple, tree, apple tree" echo ${str/apple/APPLE} # 替換第一次出現的apple echo ${str//apple/APPLE} # 替換所有apple echo ${str/#apple/APPLE} # 如果字符串str以apple開頭,則用APPLE替換它 echo ${str/%apple/APPLE} # 如果字符串str以apple結尾,則用APPLE替換它
6. 比較
[[ "a.txt" == a* ]] # 邏輯真 (pattern matching) [[ "a.txt" =~ .*\.txt ]] # 邏輯真 (regex matching) [[ "abc" == "abc" ]] # 邏輯真 (string comparision) [[ "11" < "2" ]] # 邏輯真 (string comparision), 按ascii值比較
7. 連接
s1="hello" s2="world" echo ${s1}${s2} # 當然這樣寫 $s1$s2 也行,但最好加上大括號
8. 翻轉