方式一:$0,$1,$2..
采用$0,$1,$2..等方式獲取腳本命令行傳入的參數(shù),值得注意的是,$0獲取到的是腳本路徑以及腳本名,后面按順序獲取參數(shù),當參數(shù)超過10個時(包括10個),需要使用${10},${11}....才能獲取到參數(shù),但是一般很少會超過10個參數(shù)的情況。
1.1 示例:新建一個test.sh的文件
#!/bin/bash
echo "腳本$0"
echo "第一個參數(shù)$1"
echo "第二個參數(shù)$2"
在shell中執(zhí)行腳本,結果如下
$ ./test.sh 1 2
#shell中將會輸出:
腳本./test.sh
第一個參數(shù)1
第二個參數(shù)2
1.2 下面是參數(shù)超過10個的情況,在test.sh文件寫入
#!/bin/bash
echo "腳本名$0"
echo "第一個參數(shù)$1"
echo "第二個參數(shù)$2"
echo "第三個參數(shù)$3"
echo "第四個參數(shù)$4"
……
echo "第十個參數(shù)$10"
echo "第十個參數(shù)${10}"
在shell中執(zhí)行腳本,結果如下
$ ./test.sh a b c d e f g h i j
#shell中將會輸出:
腳本名./test.sh
第一個參數(shù)a
第二個參數(shù)b
第三個參數(shù)c
第四個參數(shù)d
第五個參數(shù)e
第六個參數(shù)f
第七個參數(shù)g
第八個參數(shù)h
第九個參數(shù)i
第十個參數(shù)a0
第十個參數(shù)j
可以看到${10}正確讀取到了第十個參數(shù),而$10被分成$1讀取到第一個參數(shù)a然后拼接字符串0,于是輸出a0。
優(yōu)點:獲取參數(shù)更容易,執(zhí)行腳本時需要的輸入少
缺點:必須按照順序輸入參數(shù),如果中間漏寫則參數(shù)對應就會錯誤
方式二:getopts
語法格式:getopts [option[:]] [DESCPRITION] VARIABLE
option:表示為某個腳本可以使用的選項
":":如果某個選項(option)后面出現(xiàn)了冒號(":"),則表示這個選項后面可以接參數(shù)(即一段描述信息DESCPRITION)
VARIABLE:表示將某個選項保存在變量VARIABLE中
2.1 示例:同樣新建一個test.sh文件
while getopts ":a:b:c:" opt
do
case $opt in
a)
echo "參數(shù)a的值$OPTARG"
;;
b)
echo "參數(shù)b的值$OPTARG"
;;
c)
echo "參數(shù)c的值$OPTARG"
;;
?)
echo "未知參數(shù)"
exit 1;;
esac
done
用一個while循環(huán)加case分支獲取不同參數(shù),:a:b:c相當于定義參數(shù)的變量名,有時候可能會有未知參數(shù),所以增加一個?的分支。
在shell中執(zhí)行腳本,結果如下
$ ./test.sh -a 1 -b 2 -c 3
#在shell中的輸出
參數(shù)a的值1
參數(shù)b的值2
參數(shù)c的值3
$ ./test.sh -a 1 -c 3
#在shell中的輸出
參數(shù)a的值1
參數(shù)c的值3
$ ./test.sh -a 1 -c 3 -d 4
#在shell中的輸出
參數(shù)a的值1
參數(shù)c的值3
未知參數(shù)
優(yōu)點:由于使用了-a加參數(shù)值的方式進行一一匹配,所以不會參數(shù)匹配錯誤,同時也可以缺省參數(shù),并不會導致參數(shù)錯誤,同時也便于后期參數(shù)的擴展和移植
缺點:腳本執(zhí)行時參數(shù)需要的輸入會增多
總結:推薦使用getopts的方式進行參數(shù)傳遞
方式三:聲明變量 直接引用
先在test1.sh腳本中聲明變量AA BB CC DD
在test2.sh腳本中引用變量AA BB CC并打印
注意:執(zhí)行腳本的時候使用(. 腳本名)可以引用腳本外聲明的變量,使用(sh 腳本名)不能引用局部之外的變量
到此這篇關于詳解shell中腳本參數(shù)傳遞的兩種方式的文章就介紹到這了,更多相關shell腳本參數(shù)傳遞內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
您可能感興趣的文章:- jupyter notebook 參數(shù)傳遞給shell命令行實例
- shell傳參并將參數(shù)傳遞給sql文件的方法