取得字串的長度
 複製代碼 代碼如下:
 
代碼:
 
%x="abcd"
 
#方法一
 
%expr length $x
 
4
 
# 方法二
 
%echo ${#x}
 
4
 
# 方法三
 
%expr "$x" : ".*"
 
4
 
# expr 的協助
 
# STRING : REGEXP   anchored pattern match of REGEXP in STRING
 
尋找子串
 複製代碼 代碼如下:
 
代碼:
 
%expr index  $x "b"
 
2
 
%expr index  $x "a"
 
1
 
%expr index  $x "b"
 
2
 
%expr index  $x "c"
 
3
 
%expr index  $x "d"
 
4
 
得到子字串
 複製代碼 代碼如下:
 
代碼:
 
# 方法一
 
# expr <string> startpos length
 
%expr substr "$x" 1 3
 
abc
 
%expr substr "$x" 1 5
 
abcd
 
%expr substr "$x" 2 5
 
bcd
 
# 方法二
 
# ${x:pos:lenght}
 
%echo ${x:1}
 
bcd
 
%echo ${x:2}
 
cd
 
%echo ${x:0}
 
abcd
 
%echo ${x:0:2}
 
ab
 
%pos=1
 
%len=2
 
%echo ${x:$pos:$len}
 
bc
 
匹配Regex
 複製代碼 代碼如下:
 
代碼:
 
# 列印匹配長度
 
%expr match $x "."
 
1
 
%expr match $x "abc"
 
3
 
%expr match $x "bc"
 
0
 
字串的掐頭去尾
 複製代碼 代碼如下:
 
代碼:
 
%x=aabbaarealwwvvww
 
%echo "${x%w*w}"
 
aabbaarealwwvv
 
%echo "${x%%w*w}"
 
aabbaareal
 
%echo "${x##a*a}"
 
lwwvvww
 
%echo "${x#a*a}"
 
bbaarealwwvvww
 
其中 , # 表示掐頭, 因為鍵盤上 # 在 $ 的左面。
其中 , % 表示%,  因為鍵盤上 % 在 $ 的右面。
單個的表示最小匹配,雙個表示最大匹配。
也就是說,當匹配的有多種方案的時候,選擇匹配的最大長度還是最小長度。
字串的替換
 複製代碼 代碼如下:
 
代碼:
 
%x=abcdabcd
 
%echo ${x/a/b} # 只替換一個
 
bbcdabcd
 
%echo ${x//a/b} # 替換所有
 
bbcdbbcd
 
不能使用 regexp ,只能用 * ? 的檔案擴充方式。