取得字串的長度
複製代碼 代碼如下:
代碼:
%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 ,只能用 * ? 的檔案擴充方式。