shell擷取字串的方法

xwdreamer發表於2014-07-03

參考文獻:

linux中shell擷取字串方法總結

[Linux]如何在Shell指令碼中計算字串長度?

擷取字串的方法一共有八種,主要為以下方法

shell中擷取字串的方法有很多中,
${expression}一共有9種使用方法。
${parameter:-word}
${parameter:=word}
${parameter:?word}
${parameter:+word} 
上面4種可以用來進行預設值的替換。
${#parameter}
上面這種可以獲得字串的長度。 
${parameter%word} 最小限度從後面擷取word
${parameter%%word} 最大限度從後面擷取word
${parameter#word} 最小限度從前面擷取word
${parameter##word} 最大限度從前面擷取word
上面4個就是用來擷取字串的方法了。
有了著四種用法就不必使用cut命令來擷取字串了
第一種又可以分為四種情況,下面一一介紹。

1、使用 # 號運算子。用途是從左邊開始刪除第一次出現子字串即其左邊字元,保留右邊字元。用法為#*substr,例如:
str='http://www.你的域名.com/cut-string.html'
echo ${str#*//}
得到的結果為www.你的域名.com/cut-string.html,即刪除從左邊開始到第一個"//"及其左邊所有字元2、使用 ## 號運算子。用途是從左邊開始刪除最後一次出現子字串即其左邊字元,保留右邊字元。用法為##*substr,例如:
str='http://www.你的域名.com/cut-string.html'
echo ${str##*/}
得到的結果為cut-string.html,即刪除最後出現的"/"及其左邊所有字元
3、使用 % 號運算子。用途是從右邊開始刪除第一次出現子字串即其右邊字元,保留左邊字元。用法為%substr*,例如:
str='http://www.你的域名.com/cut-string.html'
echo ${str%/*}
得到的結果為http://www.你的域名.com,即刪除從右邊開始到第一個"/"及其右邊所有字元
4、使用 %% 號運算子。用途是從右邊開始刪除最後一次出現子字串即其右邊字元,保留左邊字元。用法為%%substr*,例如:
str='http://www.你的域名.com/cut-string.html'
echo ${str%%/*}
得到的結果為http://www.你的域名.com,即刪除從右邊開始到最後一個"/"及其右邊所有字元

第二種也分為四種,分別介紹如下:
1、從左邊第幾個字元開始以及字元的個數,用法為:start:len,例如:
str='http://www.你的域名.com/cut-string.html'
echo ${var:0:5}
其中的 0 表示左邊第一個字元開始,5 表示字元的總個數。
結果是:http:
2、從左邊第幾個字元開始一直到結束,用法為:start,例如:
str='http://www.你的域名.com/cut-string.html'
echo ${var:7}
其中的 7 表示左邊第8個字元開始
結果是:www.你的域名.com/cut-string.html
3、從右邊第幾個字元開始以及字元的個數,用法:0-start:len,例如:
str='http://www.你的域名.com/cut-string.html'
echo ${str:0-15:10}
其中的 0-6 表示右邊算起第6個字元開始,10 表示字元的個數。
結果是:cut-string
3、從右邊第幾個字元開始一直到結束,用法:0-start,例如:
str='http://www.你的域名.com/cut-string.html'
echo ${str:0-4}
其中的 0-6 表示右邊算起第6個字元開始,10 表示字元的個數。
結果是:html
注:(左邊的第一個字元是用 0 表示,右邊的第一個字元用 0-1 表示)

 

 

相關文章