Bash Getopts :让你的脚本支持命令行参数

运维 系统运维
以前我总想知道如何为我的Bash脚本创建命令行参数。经过搜索,我发现了2个函数可以处理这个问题,getopt 函数和 getopts 函数。我无意争论哪一个函数更好的。getopts 是一个shell内建命令,而且似乎比 getopt 更容易实现这个功能,所以在这篇文章里我准备讲讲getopts。

以前我总想知道如何为我的Bash脚本创建命令行参数。经过搜索,我发现了2个函数可以处理这个问题,getopt 函数和 getopts 函数。我无意争论哪一个函数更好的。getopts 是一个shell内建命令,而且似乎比 getopt 更容易实现这个功能,所以在这篇文章里我准备讲讲getopts。

[[114412]]

bash getopts

开始的时候,我只试着处理传递给脚本的命令行参数。***,我添加了另外一些有用的功能函数,使得这个脚本可以成为其他任何交互式脚本处理命令行的开始模板。我还添加了一个纯文本格式的帮助函数,让脚本更加容易阅读。

与其来一长段文字解释 getopts 在bash中是如何工作的,我认为不如直接来一个能工作的脚本更让人觉得轻松一些。

  1. #!/bin/bash
  2.  
  3. ######################################################################
  4. #This is an example of using getopts in Bash. It also contains some
  5. #other bits of code I find useful.
  6. #Author: Linerd
  7. #Website: http://tuxtweaks.com/
  8. #Copyright 2014
  9. #License: Creative Commons Attribution-ShareAlike 4.0
  10. #http://creativecommons.org/licenses/by-sa/4.0/legalcode
  11. ######################################################################
  12.  
  13. #Set Script Name variable
  14. SCRIPT=`basename ${BASH_SOURCE[0]}`
  15.  
  16. #Initialize variables to default values.
  17. OPT_A=A
  18. OPT_B=B
  19. OPT_C=C
  20. OPT_D=D
  21.  
  22. #Set fonts for Help.[译注: 这里tput用来更改终端文本属性,比如加粗,高亮等]
  23. NORM=`tput sgr0`
  24. BOLD=`tput bold`
  25. REV=`tput smso`
  26.  
  27. #Help function
  28. function HELP {
  29. echo -e \\n"Help documentation for ${BOLD}${SCRIPT}.${NORM}"\\n
  30. echo -e "${REV}Basic usage:${NORM} ${BOLD}$SCRIPT file.ext${NORM}"\\n
  31. echo "Command line switches are optional. The following switches are recognized."
  32. echo "${REV}-a${NORM} --Sets the value for option ${BOLD}a${NORM}. Default is ${BOLD}A${NORM}."
  33. echo "${REV}-b${NORM} --Sets the value for option ${BOLD}b${NORM}. Default is ${BOLD}B${NORM}."
  34. echo "${REV}-c${NORM} --Sets the value for option ${BOLD}c${NORM}. Default is ${BOLD}C${NORM}."
  35. echo "${REV}-d${NORM} --Sets the value for option ${BOLD}d${NORM}. Default is ${BOLD}D${NORM}."
  36. echo -e "${REV}-h${NORM} --Displays this help message. No further functions are performed."\\n
  37. echo -e "Example: ${BOLD}$SCRIPT -a foo -b man -c chu -d bar file.ext${NORM}"\\n
  38. exit 1
  39. }
  40.  
  41. #Check the number of arguments. If none are passed, print help and exit.
  42. NUMARGS=$#
  43. echo -e \\n"Number of arguments: $NUMARGS"
  44. if [ $NUMARGS -eq 0 ]; then
  45. HELP
  46. fi
  47.  
  48. ### Start getopts code ###
  49.  
  50. #Parse command line flags
  51. #如果选项需要后跟参数,在选项后面加":"
  52. #注意"-h"选项后面没有":",因为他不需要参数。选项字符串最开始的":"是用来去掉来自getopts本身的报错的,同时获取不能识别的选项。(译注:如果选项字符串不以":"开头,发生错误(非法的选项或者缺少参数)时,getopts会向错误输出打印错误信息;如果以":"开头,则不会打印[在man中叫slient error reporting],同时将出错的选项赋给OPTARG变量)
  53.  
  54. while getopts :a:b:c:d:h FLAG; do
  55. case $FLAG in
  56. a) #set option "a"
  57. OPT_A=$OPTARG
  58. echo "-a used: $OPTARG"
  59. echo "OPT_A = $OPT_A"
  60. ;;
  61. b) #set option "b"
  62. OPT_B=$OPTARG
  63. echo "-b used: $OPTARG"
  64. echo "OPT_B = $OPT_B"
  65. ;;
  66. c) #set option "c"
  67. OPT_C=$OPTARG
  68. echo "-c used: $OPTARG"
  69. echo "OPT_C = $OPT_C"
  70. ;;
  71. d) #set option "d"
  72. OPT_D=$OPTARG
  73. echo "-d used: $OPTARG"
  74. echo "OPT_D = $OPT_D"
  75. ;;
  76. h) #show help
  77. HELP
  78. ;;
  79. \?) #unrecognized option - show help
  80. echo -e \\n"Option -${BOLD}$OPTARG${NORM} not allowed."
  81. HELP
  82. #在这里如果你不想打印完整的帮助信息,只想显示简单的错误信息,去掉上面的两行,同时使用下面的两行。
  83. #echo -e "Use ${BOLD}$SCRIPT -h${NORM} to see the help documentation."\\n
  84. #exit 2
  85. ;;
  86. esac
  87. done
  88.  
  89. shift $((OPTIND-1)) #This tells getopts to move on to the next argument.
  90.  
  91. ### End getopts code ###
  92.  
  93.  
  94. ### Main loop to process files ###
  95.  
  96. #这里你可以用你的脚本处理逻辑来替代。这个例子只是在终端中打印文件的文件名和后缀名。你可以把任意其他的文件处理任务放到这个while-do循环中。
  97.  
  98. while [ $# -ne 0 ]; do
  99. FILE=$1
  100. TEMPFILE=`basename $FILE`
  101. #TEMPFILE="${FILE##*/}" #另外一种获取不带后缀的文件名的方法。
  102. FILE_BASE=`echo "${TEMPFILE%.*}"` #file without extension
  103. FILE_EXT="${TEMPFILE##*.}" #file extension
  104.  
  105.  
  106. echo -e \\n"Input file is: $FILE"
  107. echo "File withouth extension is: $FILE_BASE"
  108. echo -e "File extension is: $FILE_EXT"\\n
  109. shift #Move on to next input file.
  110. done
  111.  
  112. ### End main loop ###
  113.  
  114. exit 0

将上面的代码复制到你的文本编辑器里,然后保存到你的可执行路径下。我将这个脚本命名为 options 并保存到/home/linerd/bin 路径下。保存之后记得给你的脚本添加可执行权限。

  1. chmod +x ~/bin/options

现在脚本已经可以运行了。试试用 -h 参数来打印帮助信息吧。

  1. options -h

遇到不支持的选项,脚本同样可以给出提示,并打印帮助信息。

  1. options -z

***,getopts可以以任意的顺序处理你给的命令行参数。唯一的限制是你要处理的文件必须放在所有参数的***。

  1. options -d bar -c chu -b man -a foo example1.txt example2.txt

现在你可以从这些例子里看到如何通过命令行参数给脚本里的变量赋值。这个脚本里除了getopts还有很多其他的东西,但是我认为这些就足以成为一个新脚本的开头模板了。如果你有兴趣更深入地学习bash的getopts,你可以找找深埋在man page的“Builtins”这一节里的文档,也可以从 Bash Reference Manual 找到信息。

接下来呢?

你会用getops来干什么呢?在评论里告诉我吧。


via: http://tuxtweaks.com/2014/05/bash-getopts/

译者: CNprober <travelwithheart@yeah.net, QQ619913541> 校对:wxy

责任编辑:黄丹 来源: Linux中国
相关推荐

2021-08-30 07:50:42

脚本语言命令行

2018-03-29 08:30:48

Linux命令BASH

2018-08-22 09:40:27

2019-08-20 10:02:35

2017-05-25 10:32:40

命令linux系统

2020-04-26 15:38:28

Docker容器

2021-02-06 14:21:12

Linux 开发操作系统

2009-12-25 17:05:09

LINUX Bash

2023-06-25 12:00:53

2010-11-24 15:33:59

mysql命令行参数

2010-03-10 17:23:37

Python 命令行参

2010-06-23 14:28:23

LINUX Bash

2018-03-30 13:06:32

Linux命令Bash

2013-03-14 16:25:46

命令行

2010-07-20 14:02:38

Perl命令行参数

2010-07-26 09:32:41

Perl命令行

2019-10-12 10:12:13

Bash命令行Linux

2011-08-22 11:51:13

Linuxconfigure

2009-11-20 09:31:47

Linux命令命令行Linux

2023-06-08 12:37:17

点赞
收藏

51CTO技术栈公众号