得到長(zhǎng)度
  1. %x="abcd"
  2. #方法一
  3. %expr length $x
  4. 4
  5. # 方法二
  6. %echo ${#x}
  7. 4
  8. # 方法三
  9. %expr "$x" : ".*"
  10. 4
  11. # expr 的幫助
  12. # STRING : REGEXP   anchored pattern match of REGEXP in STRING
復(fù)制代碼


查找子串
  1. %expr index  $x "b"
  2. 2
  3. %expr index  $x "a"
  4. 1
  5. %expr index  $x "b"
  6. 2
  7. %expr index  $x "c"
  8. 3
  9. %expr index  $x "d"
  10. 4
復(fù)制代碼


得到子字符串
  1. # 方法一
  2. # expr <string> startpos length
  3. %expr substr "$x" 1 3
  4. abc
  5. %expr substr "$x" 1 5
  6. abcd
  7. %expr substr "$x" 2 5
  8. bcd
  9. # 方法二
  10. # ${x:pos:lenght}
  11. %echo ${x:1}
  12. bcd
  13. %echo ${x:2}
  14. cd
  15. %echo ${x:0}
  16. abcd
  17. %echo ${x:0:2}
  18. ab
  19. %pos=1
  20. %len=2
  21. %echo ${x:$pos:$len}
  22. bc
復(fù)制代碼


匹配正則表達(dá)式
  1. # 打印匹配長(zhǎng)度
  2. %expr match $x "."
  3. 1
  4. %expr match $x "abc"
  5. 3
  6. %expr match $x "bc"
  7. 0
復(fù)制代碼


字符串的掐頭去尾
  1. %x=aabbaarealwwvvww
  2. %echo "${x%w*w}"
  3. aabbaarealwwvv
  4. %echo "${x%%w*w}"
  5. aabbaareal
  6. %echo "${x##a*a}"
  7. lwwvvww
  8. %echo "${x#a*a}"
  9. bbaarealwwvvww
復(fù)制代碼

其中 , # 表示掐頭, 因?yàn)殒I盤(pán)上 # 在 $ 的左面。
其中 , % 表示%,  因?yàn)殒I盤(pán)上 % 在 $ 的右面。
單個(gè)的表示最小匹配,雙個(gè)表示最大匹配。
也就是說(shuō),當(dāng)匹配的有多種方案的時(shí)候,選擇匹配的最大長(zhǎng)度還是最小長(zhǎng)度。

字符串的替換
  1. %x=abcdabcd
  2. %echo ${x/a/b} # 只替換一個(gè)
  3. bbcdabcd
  4. %echo ${x//a/b} # 替換所有
  5. bbcdbbcd
復(fù)制代碼

不可以使用 regexp , 只能用 * ? 的文件擴(kuò)展方式。