鼓励将SHELL中变量全部用{} 括起来,便于阅读,防止变量名产生歧义。
用于实现以下场景
1 root@ngiam-db:/data# echo $SHELL 2 /bin/bash 3 root@ngiam-db:/data# comm=${SHELL}IsMyShell 4 root@ngiam-db:/data# echo $comm 5 /bin/bashIsMyShell
1 假设我们定义了一个变量为:
2 file=/dir1/dir2/dir3/my.file.txt
3 我们可以用 ${ } 分别替换获得不同的值:
4 ${file#*/}:拿掉第一条 / 及其左边的字符串:dir1/dir2/dir3/my.file.txt
5 ${file##*/}:拿掉最后一条 / 及其左边的字符串:my.file.txt
6 ${file#*.}:拿掉第一个 . 及其左边的字符串:file.txt
7 ${file##*.}:拿掉最后一个 . 及其左边的字符串:txt
8 ${file%/*}:拿掉最后条 / 及其右边的字符串:/dir1/dir2/dir3
9 ${file%%/*}:拿掉第一条 / 及其右边的字符串:(空值)
10 ${file%.*}:拿掉最后一个 . 及其右边的字符串:/dir1/dir2/dir3/my.file
11 ${file%%.*}:拿掉第一个 . 及其右边的字符串:/dir1/dir2/dir3/my
12 记忆的方法为:
13
14 # 是去掉左边(在鉴盘上 # 在 $ 之左边)
15 % 是去掉右边(在鉴盘上 % 在 $ 之右边)
16 单一符号是最小匹配﹔两个符号是最大匹配。
17
18
19 ${file:0:5}:提取最左边的 5 个字节:/dir1
20 ${file:5:5}:提取第 5 个字节右边的连续 5 个字节:/dir2
21
22 我们也可以对变量值里的字符串作替换:
23 ${file/dir/path}:将第一个 dir 提换为 path:/path1/dir2/dir3/my.file.txt
24 ${file//dir/path}:将全部 dir 提换为 path:/path1/path2/path3/my.file.txt
25
26 利用 ${ } 还可针对不同的变量状态赋值(没设定、空值、非空值):
27 ${file-my.file.txt} :假如 $file 为空值,则使用 my.file.txt 作默认值。(保留没设定及非空值)
28 ${file:-my.file.txt} :假如 $file 没有设定或为空值,则使用 my.file.txt 作默认值。 (保留非空值)
29 ${file+my.file.txt} :不管 $file 为何值,均使用 my.file.txt 作默认值。 (不保留任何值)
30 ${file:+my.file.txt} :除非 $file 为空值,否则使用 my.file.txt 作默认值。 (保留空值)
31 ${file=my.file.txt} :若 $file 没设定,则使用 my.file.txt 作默认值,同时将 $file 定义为非空值。 (保留空值及非空值)
32 ${file:=my.file.txt} :若 $file 没设定或为空值,则使用 my.file.txt 作默认值,同时将 $file 定义为非空值。 (保留非空值)
33 ${file?my.file.txt} :若 $file 没设定,则将 my.file.txt 输出至 STDERR。 (保留空值及非空值))
34 ${file:?my.file.txt} :若 $file 没设定或为空值,则将 my.file.txt 输出至 STDERR。 (保留非空值)
35
36 还有,${#var} 可计算出变量值的长度:
37 ${#file} 可得到 27 ,因为 /dir1/dir2/dir3/my.file.txt 刚好是 27 个字节...