问题描述:在linuxshell中怎样处理tail-n10access.log这样的命令行选项?

在bash中,可以用以下三种方法来处理命令行参数,每种方法都有自己的应用场景。

1,直接处理,依次对$1,$2,…,$n进行解析,分别手工处理;

2,getopts来处理,单个字符选项的情况(如:-n10-ffile.txt等选项);

3,getopt,可以处理单个字符选项,也可以处理长选项long-option(如:--prefix=/home等)。

总结:小脚本手工处理即可,getopts能处理绝大多数的情况,getopt较复杂、功能也更强悍。

1,直接手工处理位置参数

必需要要晓得几个变量linux 论坛,

*$0:即命令本身,相当于c/c++中的argv[0]

*$1:第一个参数.

*$2,$3,$4…:第2、3、4个参数,依次类推。

*$#参数的个数,不包括命令本身

*$@:参数本身的列表,也不包括命令本身

*$*:和$@相同linux命令行参数,但”$*”和”$@”(加破折号)并不同,”$*”将所有的参数解释成一个字符串,而”$@”是一个参数字段。

手工处理方法能满足多数的简单需求,配合shift使用也能构造出强悍的功能,但处理复杂选项时建议用下边的两种方式。

事例,(getargs.sh):

复制代码代码示例:

#!/bin/bash

if[$#-lt1];then

echo”error..needargs”

exit1

fi

echo”commondis$0″

echo”argsare:”

forargin”$@”

do

echo$arg

done

运行命令:

复制代码代码示例:

./getargs.sh1122cc

commondis./getargs.sh

argsare:

11

22

cc

2,getopts(shell外置命令)

处理命令行参数是一个相像而又复杂的事情,因此,c提供了getopt/getopt_long等函数,c++的boost提供了options库,在shell中,处理此事的是getopts和getopt。

getopts/getopt的区别,getopt是个外部binary文件,而getopts是shellbuiltin。

复制代码代码示例:

[root@jbxue~]$typegetopt

getoptis/usr/bin/getopt

[root@jbxue~]$typegetopts

getoptsisashellbuiltin

getopts不能直接处理长的选项(如:--prefix=/home等)

关于getopts的使用方式,可以manbash搜索getopts

getopts有两个参数,第一个参数是一个字符串,包括字符和“:”,每一个字符都是一个有效的选项linux命令行参数,假如字符旁边带有“:”,表示这个字符有自己的参数。getopts从命令中获取这种参数,而且删掉了“-”,并将其形参在第二个参数中,假如带有自己参数,这个参数形参在“optarg”中。提供getopts的shell外置了optarg这个变变,getopts更改了这个变量。

这儿变量$optarg储存相应选项的参数,而$optind总是储存原始$*中下一个要处理的元素位置。

whilegetopts”:a:bc”opt#第一个逗号表示忽视错误;字符旁边的逗号表示该选项必须有自己的参数

linux命令行参数_linux命令 shell命令_linux命令跳到指定行

事例,(getopts.sh):

复制代码代码示例:

echo$*

whilegetopts”:a:bc”opt

do

case$optin

a)echo$optarg

echo$optind;;

b)echo”b$optind”;;

c)echo”c$optind”;;

?)echo”error”

exit1;;

esac

done

echo$optind

shift$(($optind-1))

#通过shift$(($optind-1))的处理,$*中就只保留了去除选项内容的参数,可以在其后进行正常的shell编程处理了。

echo$0

echo$*

执行命令:

复制代码代码示例:

./getopts.sh-a11-b-c

-a11-b-c

11

3

b4

c5

5

./getopts.sh

3,getopt(一个外部工具)

具体用用法可以mangetopt

#-o表示短选项,两个引号表示该选项有一个可选参数,可选参数必须贴近选项,如-carg而不能是-carg

#--long表示长选项

事例,(getopt.sh):

复制代码代码示例:

#!/bin/bash

#asmallexampleprogramforusingthenewgetopt(1)program.

#thisprogramwillonlyworkwithbash(1)

#ansimilarprogramusingthetcsh(1)script.languagecanbefound

#asparse.tcsh

#exampleinputandoutput(fromthebashprompt):

#./parse.bash-apar1’anotherarg’--c-long’wow!*?’-cmore-b”verylong”

#optiona

#optionc,noargument

#optionc,argument`more’

#optionb,argument`verylong’

#remainingarguments:

#-->`par1′

linux命令行参数_linux命令跳到指定行_linux命令 shell命令

#-->`anotherarg’

#-->`wow!*?’

#notethatweuse`”$@”‘toleteachcommand-lineparameterexpandtoa

#separateword.thequotesaround`$@’areessential!

#weneedtempasthe`evalset--‘wouldnukethereturnvalueofgetopt.

#-o表示短选项,两个引号表示该选项有一个可选参数puppy linux,可选参数必须贴近选项

#如-carg而不能是-carg

#--long表示长选项

#”$@”在里面解释过

#-n:出错时的信息

#--:举一个反例比较好理解:

#我们要创建一个名子为”-f”的目录你会怎样办?

#mkdir-f#不成功,由于-f会被mkdir当成选项来解析,这时就可以使用

#mkdir—f这样-f就不会被作为选项。

temp=`getopt-oab:c::--longa-long,b-long:,c-long::

-n’example.bash’--“$@”`

if[$?!=0];thenecho”terminating…”>&2;exit1;fi

#notethequotesaround`$temp’:theyareessential!

#set会重新排列参数的次序,也就是改变$1,$2…$n的值,这种值在getopt中重新排列过了

evalset--“$temp”

#经过getopt的处理,下边处理具体选项。

whiletrue;do

case”$1″in

-a|--a-long)echo”optiona”;shift;;

linux命令行参数_linux命令跳到指定行_linux命令 shell命令

-b|--b-long)echo”optionb,argument`$2′”;shift2;;

-c|--c-long)

#chasanoptionalargument.asweareinquotedmode,

#anemptyparameterwillbegeneratedifitsoptional

#argumentisnotfound.

case”$2″in

“”)echo”optionc,noargument”;shift2;;

*)echo”optionc,argument`$2′”;shift2;;

esac;;

--)shift;break;;

*)echo”internalerror!”;exit1;;

esac

done

echo”remainingarguments:”

forargdo

echo’-->'”`$arg'”;

done

运行命令:

复制代码代码示例:

./getopt.sh--b-longabc-a-c33remain

optionb,argument`abc’

optiona

optionc,argument`33′

remainingarguments:

-->`remain’

以上就是有关linuxshell命令行选项与参数用法的详尽内容,希望对你们有所帮助。

Tagged:
Author

这篇优质的内容由TA贡献而来

刘遄

《Linux就该这么学》书籍作者,RHCA认证架构师,教育学(计算机专业硕士)。

发表回复