轉載:http://www.cnblogs.com/frydsh/p/3261012.html
1. 取長度
1
2
3
4
|
str= "abcd" expr length
$str #
4 echo ${ #str}
# 4 expr "$str" :
".*" #
4 |
2. 查找子串的位置
1
2
3
4
5
|
str= "abc" expr index
$str "a" #
1 expr index
$str "b" #
2 expr index
$str "x" #
0 expr index
$str "" #
0 |
3. 選取子串
1
2
3
4
5
6
7
8
9
|
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. 截取子串
1
2
3
4
5
6
7
8
9
10
11
12
13
|
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. 字符串替換
1
2
3
4
5
6
|
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. 比較
1
2
3
4
|
[[
"a.txt" ==
a* ]] #
邏輯真 (pattern matching) [[
"a.txt" =~
.*\.txt ]] #
邏輯真 (regex matching) [[
"abc" ==
"abc" ]]
#
邏輯真 (string comparision) [[
"11" <
"2" ]]
#
邏輯真 (string comparision), 按ascii值比較 |
7. 連接
1
2
3
|
s1= "hello" s2= "world" echo ${s1}${s2}
#
當然這樣寫 $s1$s2 也行,但最好加上大括號 |