${ } 用於字符串時常常用做變量的替換
今天看一個腳本例子的時候有些地方不太懂,所以上網查了下,覺得很不錯,保留下來,供大家參考!
假設我們定義了一個變量爲:
可以用${ }分別替換得到不同的值:
${file%%/*}:刪掉第一個 / 及其右邊的字符串:(空值)
${file%%.*}:刪掉第一個 . 及其右邊的字符串(可以看作是從右邊數最後一個.開始)
# 是 去掉左邊(鍵盤上#在 $ 的左邊)
%是去掉右邊(鍵盤上% 在$ 的右邊)
單一符號是最小匹配;兩個符號是最大匹配
${file:5:5}:提取第 5 個字節右邊的連續5個字節: //從0開始計數
/henr
也可以對變量值裏的字符串作替換:
${file//my/your}:將全部my替換爲 your:
利用 ${ } 還可針對不同的變數狀態賦值(沒設定、空值、非空值):
${file-my.file.txt} :假如$file沒有設定,則使用 my.file.txt 作傳回值。(空值及非空值時不作處理)
${file:-my.file.txt} :假如$file沒有設定或爲空值,則使用 my.file.txt 作傳回值。 (非空值時不作處理)
${file+my.file.txt} :假如 $file 設為空值或非空值,均使用 my.file.txt 作傳回值。(沒設定時不作處理)
${file:+my.file.txt} :若 $file 為非空值,則使用 my.file.txt作傳回值。 (沒設定及空值時不作處理)
${file=my.file.txt} :若 $file 沒設定,則使用 my.file.txt 作傳回值,同時將 $file 賦值為 my.file.txt。 (空值及非空值時不作處理)
${file:=my.file.txt} :若 $file 沒設定或為空值,則使用 my.file.txt 作傳回值,同時將 $file 賦值為my.file.txt 。 (非空值時不作處理)
${file?my.file.txt} :若 $file 沒設定,則將my.file.txt 輸出至 STDERR。 (空值及非空值時不作處理)
${file:?my.file.txt} :若 $file 沒設定或爲空值,則將 my.file.txt 輸出至 STDERR。 (非空值時不作處理)
${#var} 可計算出變量值的長度:
${#file} 可得到 36 ,因爲/home/henry/myshells/myfile.test.txt共計36個字節