1. 命令行参数
1.1 参数之间空格分隔,格式:$+position, e.g. $0, $1, $2, 其中$0表示脚本名字,超过10个参数时,e.g. 第10个参数用${10}表示;
1.2 简单示例:
1.3 通过建立软连接的方式,同一个脚本,根据不同脚本名字,运行不同脚本内容,e.g.:
2. 命令行参数变量的处理
2.1 通过条件判断,进行错误检测:
2.2 通过shift命令,进行移动位置参数:
2.3 命令行参数选项处理:
2.3.1 简单选项处理,e.g.:
2.3.2 分离选项和参数,e.g.:
#!/bin/sh while [ -n "$1" ] do case "$1" in -a) echo "Option a" ;; -b) echo "Option b" ;; -c) echo "Option c" ;; --) shift break;; esac shift done echo “The param is: $*”
2.3.3 处理带值选项,e.g:
#!/bin/sh while [ -n "$1" ] do ca -a) echo "Option a" ;; -b) value=“$2” shift echo "Option b, value is $value" ;; -c) echo "Option c" ;; --) shift break;; esac shift done echo "The param is: $*"
(备注:如上操作只能处理单个选项的时候,当出现选项合并的时候,e.g. --ab则无法处理)
2.3.4 getopt命令, 用于选项格式化,e.g:
#!/bin/sh # b后面的冒号表示b选项带有参数 set -- `getopt ab:c "$@"` while [ -n "$1" ] do case "$1" in -a) echo "Option a" ;; -b) value="$2" echo "Option b, value is $value" shift;; -c) echo "Option c" ;; --) shift break;; esac shift done echo "The param is: $*"
2.3.5 当参数值带有空格的时候,getopt命令则无法进行解析,需要用到getopts命令,e.g:
#!/bin/sh while getopts ab:c opt do case "$opt" in a) echo "option a" ;; b) echo "option b, value is: $OPTARG" ;; c) echo "option c" ;; *) echo “unknown option: $opt” ;; esac done shift $[ $OPTIND-1] count=1 for param in "$@" do echo "param $count is: $param" count=$[ $count+1 ] done
备注:
OPTIND:getopts使用OPTIND作为索引,来处理下一个需要处理的参数,记录当前的状态;
OPTARG:在上面的循环中,a,b两个参数后面各有一个冒号,冒号表示该输入的参数后面还有一个参数值,当getopts发现冒号后,会处理用户输入的参数值,这个参数值被保存在OPTARG中。
3. 在脚本中获取用户输入 (分别通过重定向的方式和管道命令方式进行读取)
原文:http://blog.csdn.net/swordgirl2011/article/details/51239502