shell传递参数的两种方式(详解版)

第一种

我们可以在执行 Shell 脚本时,向脚本传递参数,脚本内获取参数的格式为:$n。n 代表一个数字,1 为执行脚本的第一个参数,2 为执行脚本的第二个参数,以此类推……

实例
以下实例我们向脚本传递三个参数,并分别输出,其中 $0 为执行的文件名:

#!/bin/bash
echo "Shell 传递参数实例!";
echo "执行的文件名:$0";
echo "第一个参数为:$1";
echo "第二个参数为:$2";
echo "第三个参数为:$3";

为脚本设置可执行权限,并执行脚本,输出结果如下所示:

$ chmod +x test.sh 
$ ./test.sh 1 2 3

执行的文件名:./test.sh
第一个参数为:1
第二个参数为:2
第三个参数为:3

另外,还有几个特殊字符用来处理参数:

参数处理 说明

$#	传递到脚本的参数个数
$*	以一个单字符串显示所有向脚本传递的参数。
     如"$*"用「"」括起来的情况、以"$1 $2 … $n"的形式输出所有参数。
$$	脚本运行的当前进程ID号
$!	后台运行的最后一个进程的ID号
$@	与$*相同,但是使用时加引号,并在引号中返回每个参数。
    如"$@"用「"」括起来的情况、以"$1" "$2" … "$n" 的形式输出所有参数。
$-	显示Shell使用的当前选项,与set命令功能相同。
$?	显示最后命令的退出状态。0表示没有错误,其他任何值表明有错误。
#!/bin/bash
echo "Shell 传递参数实例!";
echo "第一个参数为:$1";
echo "参数个数为:$#";
echo "传递的参数作为一个字符串显示:$*";

执行脚本,输出结果如下所示:

$ chmod +x test.sh 
$ ./test.sh 1 2 3
第一个参数为:1
参数个数为:3
传递的参数作为一个字符串显示:1 2 3
 $* 与 $@ 区别:

相同点:都是引用所有参数。
不同点:只有在双引号中体现出来。假设在脚本运行时写了三个参数 1、2、3,,则 " * " 等价于 “1 2 3”(传递了一个参数),而 “@” 等价于 “1” “2” “3”(传递了三个参数)。

#!/bin/bash
echo "-- \$* 演示 ---"
for i in "$*"; do
    echo $i
done

echo "-- \$@ 演示 ---"
for i in "$@"; do
    echo $i
done

执行脚本,输出结果如下所示:

$ chmod +x test.sh 
$ ./test.sh 1 2 3
-- $* 演示 ---
1 2 3
-- $@ 演示 ---
1
2
3

第二种getops

getopts是一个解析脚本选项参数的工具。

语法格式:getopts [option[:]] [DESCPRITION] VARIABLE

option: 表示为某个脚本可以使用的选项.

“:”: 如果某个选项(option)后面出现了冒号(”:”),则表示这个选项后面可以接参数(即一段描述信息DESCPRITION)

VARIABLE:表示将某个选项保存在变量VARIABLE中

getopts是linux系统中的一个内置变量,一般用在循环中。每当执行循环是,getopts都会检查下一个命令选项,如果这些选项出现在option中,则表示是合法选项,否则不是合法选项。并将这些合法选项保存在VARIABLE这个变量中。
getopts还包含两个内置变量,及OPTARG和OPTIND

  • OPTARG就是将选项后面的参数(或者描述信息DESCPRITION)保存在这个变量当中。
  • OPTIND:这个表示命令行的下一个选项或参数的索引(文件名不算选项或参数)

初次使用要注意这几点:

1)脚本位置参数会与optstring中的单个字母逐个匹配,如果匹配到就赋值给name,否则赋值name为问号;
2)optstring中单个字母是一个选项,如果字母后面加冒号,表示该选项后面带参数,参数值并会赋值给OPTARG变量;
3)optstring中第一个是冒号,表示屏蔽系统错误(test.sh: illegal option — h);
4)允许把选项放一起,例如-ab

实验

1、getops参数简单使用

#!/bin/bash
while getopts ':b:d:' OPT &> /dev/null;do
 case $OPT in
 b)
 echo "The options is b"
 echo $OPTARG ;;
 d)
 echo "The options is d"
 echo $OPTARG ;;
 *)
 echo "Wrong Options"
 exit 7 ;;
 esac
# echo $OPT
# echo $OPTARG
done
echo $OPTIND
shift $[$OPTIND-1]
echo $1

在这里插入图片描述
详解shell脚本中关于getopts的使用方法
执行结果:

 ./getopts1.sh -d 'nice' fixnale

在这里插入图片描述
说明:

当输入-d时, O P T = d , OPT=d, OPT=d,OPTARG=’nice’,因此就会显示d)…这一部分的信息。

由于这里有一个选项(-d)和一个参数(‘nice’),$OPTIND指向命令行中下一个选项或参数的索引位置,因此这里即为3。

shift [ [ [OPTIND-1]表示将文件名前面的选项和参数踢掉.

2、getops参数进一步使用

#!/bin/bash
echo $*
while getopts ":a:bc:" opt
do
 case $opt in
 a)
 echo $OPTARG $OPTIND;;
 b)
 echo "b $OPTIND";;
 c)
 echo "c $OPTIND";;
 ?)
 echo "error"
 exit 1;;
 esac
done
echo $OPTIND
shift $(( $OPTIND-1 ))
echo $0
echo $*

在这里插入图片描述
详解shell脚本中关于getopts的使用方法
执行结果:

./getopts2.sh -a 11 -b -c 6

详解shell脚本中关于getopts的使用方法
说明:

while getopts “:a:bc:” opt #第一个冒号表示忽略错误;字符后面的冒号表示该选项必须有自己的参数。

$optarg 存储相应选项的参数,如上例中的11、6;

$optind 总是存储原始$*中下一个要处理的选项(不是参数,而是选项,此处指的是a,b,c这三个选项,而不是那些数字,当然数字也是会占有位置的)位置。

optind初值为1,遇到”x”,选项不带参数,optind+=1;遇到”x:”,带参数的选项,optarg=argv[optind+1],optind+=2;遇到”x::”,可选参数,属于#1和#2之一。

第一行输出echo $*

第二行,optind初值为1,选项-a的参数为11,下一个要处理的选项-b位置为3,所以输出:11 3;

第三行,然后-b要处理的下一个选项-c位置为4,所以输出:b 4;

第四行,再者-c有参数,所以下一个要处理的位置+2,所以输出:c 6;

猜你喜欢

转载自blog.csdn.net/low5252/article/details/103646475