shell getopts命令

由于shell命令行的灵活性,自己编写代码判断时,复杂度会比较高。使用内部命令 getopts 可以很方便地处理命令行参数。一般格式为:

getopts optstring name [args]
       getopts 的设计目标是在循环中运行,每次执行循环,getopts 就检查下一个命令行参数,并判断它是否合法。即检查参数是否以 - 开头,后面跟一个包含在 options 中的字母。如果是,就把匹配的选项字母存在指定的变量 variable 中,并返回退出状态0;如果 - 后面的字母没有包含在 options 中,就在 variable 中存入一个 ?,并返回退出状态0;如果命令行中已经没有参数,或者下一个参数不以 - 开头,就返回不为0的退出状态。

getopts引用的三个环境变量:

OPTARG: 上一个由getopts内置命令处理的选项参数的值, option argument(存放选项参数),当选项需要选项参数时,getopts 命令就将其置于变量 OPTARG 中

OPTIND:  下一个由getopts内置命令处理的参数的序号,option index,每次调用脚本它都会被初始值为1,会逐次递增。

OPTERR: 如果设为1,bash会显示getopts的错误。设为0,不显示getopts的错误。

getopts 的处理过程:
  调用脚本时,OPTIND为初始化为1。每调用一次getopts,就将下一个选项值赋给name , 选项索引值OPTIND也会指向下一个要处理选项的位置,选项参数则会赋给OPTARG
  getopts 的设计目标是在循环中运行,每执行一次,getopts就检查下一个命令行参数,并判断它是否有效。(即检查参数是否以-开头,后面跟一个包含在opstring中的字母)。
  有效,则把匹配的选项字母存在指定的变量variable中,并返回退出状态0(ture);
  无效(如果-后面的字母没有包含在options),就在 variable 中存入一个?,并返回退出状态0;如果命令行中已经没有参数,或者下一个参数不以-开头,就返回不为0的退出状态(false, 可用于结束while 循环)。
 getopts处理完所有参数后,会返回一个非0值(false,退出循环),此时OPTIND索引值指向第一个非选项的参数[args],name置为?

getopts 错误处理
  正确使用命令时,name用来存储option, $OPTARG用来存放option的参数。若命令输入有误(选项无效,缺少参数),getopts会处理illegal option错误和miss option argument错误。处理结果与opstring是否以:开头而不同。opstring 开头的:用于屏蔽getopts处理时的错误消息(脚本中将OPTERR置于0也可以达到同样的效果)。

举个栗子

#!/bin/bash
while getopts u:p:n option
do 
    case "$option" in
        u)
            echo "option:u, value $OPTARG"
            echo "next arg index:$OPTIND";;
        p)
            echo "option:p"
            passwd=$OPTARG
            echo "next arg index:$OPTIND"
            echo "PASSWD IS: $passwd";;
        n)
            echo "option:N"
            echo "next arg index:$OPTIND";;
        ?)
            echo "Usage: args [-U] [-p] [-n]"
            echo "-u means uses"
            echo "-p means passwd"
            echo "-n means name"
            exit 1;;
    esac
done

原文链接:https://www.cnblogs.com/hello-wei/p/9778407.html
快,滋醒这个做梦的人,有糖尿病的往后靠靠哈,不要给他点甜头!
原文地址:https://www.cnblogs.com/jianzhaojing/p/11451652.html