一般情況下$var與${var}是沒(méi)有區(qū)別的,但是用${ }會(huì)比較精確的界定變量名稱的范圍
[root@localhost ~]# A=Linux [root@localhost ~]# echo $AB #表示變量AB [root@localhost ~]# echo ${A}B #表示變量A后連接著B LinuxB
除此之外${}還有很多其他功能如下:
測(cè)試變量聲明:
file=/dir1/dir2/dir3/my.file.txt
命令 | 解釋 | 結(jié)果 |
---|---|---|
${file:0:5} | 提取最左邊的 5 個(gè)字節(jié) | /dir1 |
${file:5:5} | 提取第 5 個(gè)字節(jié)右邊的連續(xù) 5 個(gè)字節(jié) | /dir2 |
${file/dir/path} | 將第一個(gè) dir 提換為 path | /path1/dir2/dir3/my.file.txt |
${file//dir/path} | 將全部 dir 提換為 path | /path1/path2/path3/my.file.txt |
${#file} | 獲取變量長(zhǎng)度 | 27 |
命令 | 解釋 | 備注 |
---|---|---|
${file-my.file.txt} | 若 $file 沒(méi)設(shè)定,則使用 my.file.txt 作傳回值 | 有設(shè)定( 空值及非空值)不作處理 |
${file:-my.file.txt} | 若 $file 沒(méi)設(shè)定或?yàn)榭罩?則使用 my.file.txt 作傳回值 | 非空值時(shí)不作處理 |
${file+my.file.txt} | 若$file 有設(shè)定(空值或非空值),均使用my.file.txt作傳回值 | 沒(méi)設(shè)定時(shí)不作處理 |
${file:+my.file.txt} | 若 $file 有設(shè)定且不為空值(為非空值),則使用 my.file.txt 作傳回值 | 沒(méi)設(shè)定及空值不作處理 |
${file=txt} | 若 $file 沒(méi)設(shè)定,則回傳 txt ,并將 $file 賦值為 txt | 有設(shè)定( 空值及非空值)不作處理 |
${file:=txt} | 若 $file 沒(méi)設(shè)定或空值,則回傳 txt ,將 $file 賦值為txt | 非空值時(shí)不作處理 |
${file?my.file.txt} | 若 $file 沒(méi)設(shè)定,則將 my.file.txt 輸出至 STDERR | 有設(shè)定( 空值及非空值)不作處理 |
${file:?my.file.txt} | 若 $file沒(méi)設(shè)定或空值,則將my.file.txt輸出至STDERR | 非空值時(shí)不作處理 |
tips:
以上的理解在于, 你一定要分清楚 unset 與 null 及 non-null 這三種賦值狀態(tài). 一般而言, : 與 null 有關(guān), 若不帶 : 的話, null 不受影響, 若帶 : 則連 null 也受影響.
示例如下:
命令 | 解釋 | 結(jié)果
${file#*.} 拿掉第一個(gè) . 及其左邊的字符串 file.txt
[root@localhost ~]# echo ${file#*.} file.txt
${file##*.} 拿掉最后一個(gè) . 及其左邊的字符串 txt
[root@localhost ~]# echo ${file##*.} txt
${file%.*} 拿掉最后一個(gè) . 及其右邊的字符串 /dir1/dir2/dir3/my.file
[root@localhost ~]# echo ${file%.*} /dir1/dir2/dir3/my.file
${file%%.*} 拿掉第一個(gè) . 及其右邊的字符串 /dir1/dir2/dir3/my
[root@localhost ~]# echo ${file%%.*} /dir1/dir2/dir3/my
上面是網(wǎng)上的解釋,按照上面示例,好像${}只能用單字符定界,實(shí)際可以用字符串,并且也不是只能匹配刪除定界字符串的一側(cè),實(shí)際可以兩邊同時(shí)匹配刪除(但是因?yàn)榇嬖谛惺谆蛐形捕ń纾?模式指定匹配行首必刪除行首一側(cè),%模式同理,看下面解釋)
補(bǔ)充:經(jīng)測(cè)試發(fā)現(xiàn),實(shí)際上這里#和%指代的是匹配字符串開頭或者結(jié)尾,指定匹配正則中的^或者$。連續(xù)的#和$,類似于正則的貪婪匹配和最短匹配,*相當(dāng)于標(biāo)準(zhǔn)正則中的.* ,類似于的shell命令中的匹配模式。 ${}實(shí)際上就是以這種非標(biāo)準(zhǔn)正則的方式匹配字符串,然后截取刪除。
示例如下:
${file##/*.fi} 最長(zhǎng)匹配,但是沒(méi)有匹配到后面的"." ,因?yàn)檫@里匹配的是"/*.fi",.fi與.txt不匹配,而前面的/*
等價(jià)于正則的^/*,可以匹配字符串前面部分。
[root@test ~]# echo ${file##/*.fi} le.txt
如果換成{file##d*.},因?yàn)槭瞧ヅ渥址_頭模式,前面的d*等價(jià)于匹配正則的^d*,匹配失敗返回原字符串
[root@test ~]# echo ${file##d*.} /dir1/dir2/dir3/my.file.txt
${file#*.*t} 最短匹配,這里匹配是"*.*t",可以匹配.txt前面部分,結(jié)果如下
[root@test ~]# echo ${file#*.*t} xt
${file%dir*xt} 匹配行尾部分
[root@test ~]# echo ${file%dir*xt} /dir1/dir2/
這里的*也不是必要的,沒(méi)有同樣可以匹配成功
[root@test ~]# echo ${file%le.txt} /dir1/dir2/dir3/my.fi
因此${}中#和$就是用類似正則的方式指定匹配行首或者行尾匹配刪除字符
A="a b c def" # 定義變量 A=(a b c def) # 定義數(shù)組
命令 | 解釋 | 結(jié)果 |
---|---|---|
${A[@]} | 返回?cái)?shù)組全部元素 | a b c def |
${A[*]} | 同上 | a b c def |
${A[0]} | 返回?cái)?shù)組第一個(gè)元素 | a |
${#A[@]} | 返回?cái)?shù)組元素總個(gè)數(shù) | 4 |
${#A[*]} | 同上 | 4 |
${#A[3]} | 返回第四個(gè)元素的長(zhǎng)度,即def的長(zhǎng)度 | 3 |
A[3]=xzy | 則是將第四個(gè)組數(shù)重新定義為 xyz |
單獨(dú)聲明變量后,同樣可以以數(shù)組方式取值
[root@test ~]# B="12 3 4" [root@test ~]# echo ${B[*]} 12 3 4 [root@test ~]# echo ${#B[*]} 1 [root@test ~]# echo ${B[0]} 12 3 4
聯(lián)系客服