shell脚本命令⾏参数简介
之所以⽤到命令⾏参数,关键在于shell脚本需要与运⾏脚本的⼈员进⾏交互。
bash shell提供了命令⾏参数添加在命令后⾯的数据值)、命令⾏选项修改命令⾏为的单字符值)和直接读取键盘输⼊。
1、命令⾏参数
向shell脚本传递数据的最基本⽅式是使⽤命令⾏参数。
1)读取参数
读取输⼊的参数的变量为位置参数,位置参数通过标准数字表⽰,
其中$0为程序名称,$1为第⼀个参数,$2为第⼆个参数,依次类推,直到$9为第九个参数。
shell脚本⾃动将命令⾏参数赋值给各个位置变量。
同时输⼊多个参数可以是数值也可以是字符串)时,必须使⽤空格分隔要想在参数值中包含空格,就必须使⽤单引号或双引号)
当参数多于9个后,必须在shell脚本内使⽤⼤括号将变量括起来,如${10}。从⽽可以使⽤任意个参数。
2)读取程序名称
传递给变量$0的字符串实际上是程序的路径根据调⽤⽅法决定是相对还是绝对路径)。
使⽤basename命令可以去掉路径前缀,只获得程序名称名字中不可以有空格)。
3)测试脚本
当脚本认为应该包含参数,却实际上没有数据时,就会出错。
好的⽅法是对参数进⾏检查来保证使⽤参数前确实存在数据,可以使⽤-n参数来检查。
例⼦:if [ –n “$1” ] then .. else .. fi
2、特殊的参数变量
⽤于跟踪命令⾏参数
1)参数计数
使⽤特殊变量$#测试执⾏脚本时包含的命令⾏参数个数。脚本中任何位置都可以使⽤$#
例⼦:if [ $# –ne 2 ] 即可测试参数个数
可以使⽤${!#}来返回最后⼀个命令⾏参数当⽆参数时,$#为0,⽽${!#}为程序名)
2)获取所有数据
变量$*将命令⾏中提供的所有参数作为⼀个单词处理,它将多个参数看成⼀个参数。
变量$@将命令⾏中提供的所有参数作为同⼀个字符串中的多个单词处理。允许对其中的值进⾏迭代⼀般使⽤for),分隔开不同参数
3、移位
shift命令能够改变命令⾏参数的相对位置。默认将每个参数变量左移⼀个位置变量$0不变,把$1丢弃,注意不可以恢复了!)
shell代码在不清楚参数数⽬情况下,这是⼀个迭代参数的好办法。
可以为shift提供⼀个参数,来实现多位移变化。
4、处理选项
选项是由破折号引导的单个字母,⽤于更改命令的⾏为。
1,出选项
1)处理简单选项
可以使⽤处理命令⾏参数相同的⽅法处理选项,抽取时使⽤case语句进⾏判断是否符合选项格式。
2)从参数中分离选项
同时使⽤选项和参数时,可以使⽤--指⽰选项列表的结束。发现--后,shell就知道后⾯的是普通参数了,停⽌使⽤case处理选项。
3)处理带值的选项
选项后紧跟参数值,⼀种⽅法是在case中对应选项后使⽤shift和读后⼀位参数的⽅法处理。更好的⽅法如下:
2,使⽤getopt命令
getopt命令在处理选项和参数时⾮常⽅便。它对参数进⾏重新组织,以便于解析
1)命令格式
getopt可以接受任意形式的选项和参数列表,并⾃动将它们转换为适当的格式。
命令格式为: getopt options optstring parameters
选项字符串(opstring)⽤于定义命令⾏中的有效选项字母,以及哪些选项字母需要参数值。
2)脚本中使⽤getopt
需要使⽤set命令将现有的命令⾏选项和参数替换为getopt命令⽣成的格式化形式。
需要将原始脚本命令⾏参数送给getopt命令,然后将getopt命令输出送给set命令,如下:set – `getopts –q ab:cd “$@”`
但是getopt命令不能很好的处理带有空格的参数值,它将空格解析为参数分隔符,⽽不是将双引号引起来的两个值合并成⼀个参数。解决办法如下:
3)更⾼级的getopts命令
getopts命令顺序的对现有的shell参数变量进⾏处理,每调⽤⼀次,只处理命令中检测到的参数中的⼀个。处理完所有参数后,以⼤于0的退出状态退出。
⾮常适宜于在循环中解析所有命令⾏参数
格式为: getopts optstring variable
$optarg包含需要参数值的选项要使⽤的值,$optind包含getopts停⽌处理时在参数列表中的位置。
注意:当getopts处理时,会将选项前的-去掉,所以对应的case中不需要破折号。
好的特性:
1)可以在参数值中包含空格
2)选项字母和参数值中间可以没有空格
3)将在命令⾏中到的未定义的选项都绑定为单⼀的输出——问号
5、标准化选项
有⼀些字母选项具有标准含义。最好按照标准含义定义选项意义
-a –c –d –e –f –h –i –l –n –o –q –r –s –v- x –y
6、获取⽤户输⼊
当需要在执⾏过程中获得执⾏脚本⼈员的输⼊,使⽤read命令
1)基本读取
read命令接受标准输⼊或其他⽂件描述符输⼊。读⼊后将数据放⼊⼀个标准变量中。
-p 允许在read命令⾏中直接指定⼀个提⽰。
可以指定多个变量,也可以不指定将放置在reply环境变量中)
2)计时
使⽤-t指定⼀个计时器,计时数满还未输⼊,read返回⼀个⾮0的退出状态。
使⽤-n指定输⼊的字符个数,输⼊达到预定数⽬时,就⾃动结束输⼊
3)默读
使⽤-s使输⼊不显⽰在终端例如输⼊密码)
4)读取⽂件
最常⽤的⽅法是使⽤cat命令,并通过管道传给包含read的while语句。
例⼦:
复制代码代码⽰例:
复制代码代码如下:
cat test | while read line
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论