首页 > 代码库 > perl getopt 使用方法

perl getopt 使用方法

我们在linux常常用到一个程序需要加入参数,现在了解一下perl中的有关控制参数的函数.getopt.在linux有的参数有二种形式.一种是--help,另一种是-h.也就是-和--的分别。--表示完整参数.-表示简化参数.

在perl中也分这二种.

Getopt::Std模块的功能: 初始化perl命令行中所接受的参数,简化了命令行参数的解析。 简化参数例子:

 #!/usr/bin/perl -w
use strict;
use Getopt::Std;
 
use vars qw($opt_a $opt_b $opt_c);
getopts(‘d:f:p:‘);
 
print "\$opt_a =>; $opt_a\n" if $opt_a;
print "\$opt_b =>; $opt_b\n" if $opt_b;
print "\$opt_c =>; $opt_c\n" if $opt_c;

输出如下: [root@mail test]# ./getopt.pl -a aa -b bb -c cc $opt_a =>; aa $opt_b =>; bb $opt_c =>; cc

 [ 解释一下"d:f:p",d和f后有冒号,表示-d,-f后面要跟参数。p后面没有冒号,表示-p后面不带参数。
而且-d,-f后所跟的参数分别赋给变量$opt_d和$opt_f。对于变量$opt_p,若命令行加了-p,则$opt_p=1,否则为0]

完整参数

 Getopt::Long ,比直接使用 @ARGV 的数组强大多了.

初始化 Perl命令行中所接受的参数,简化了命令行参数的解析。下面看程序的例子
#!/usr/bin/perl
use strict;
use Getopt::Long;
use Smart::Comments;

my @libs    = ();
my %flags   = ();
my ( $verbose, $all, $more, $diam, $debug, $test, $step);

GetOptions(
        ‘verbose+‘  => \$verbose,
        ‘more!‘     => \$more,
        ‘debug:i‘   => \$debug,
        ‘lib=s‘     => \@libs,
        ‘flag=s‘    => \%flags,
        ‘test|t‘    => \$test,
        ‘all|everything|universe‘ => $all,
);

下面是详解

  •   ‘verbose+’  接有 + 的选项不接收变量,后面不需要加内容。直接使用就行了,会在每次出现时增加一次变量,就是讲命行时在参数中 -verbose -verbose 出现二次时 verbose 的值就会变成 2。
  • ‘more!’        接有 ! 的选项不接收变量(也就是讲后面不需要加参数 –more 来使用就行了),只要命令行中出现了这个参数,就会默认是 1 ,是用来设置打开和关掉一个功能的>。可以在参数前加 no 变成负的例如-nomore.
  • ‘flag=s’        接有 = 的字符串要求接字符串(s)、整数(i),或者浮点(f)等类型的变量.
  • ‘debug:i’      接有 : 的选项会接受缺省为0或者为空字符串的可选变量 
  • ‘test|t’          接有 | 的选项表示可以给 –test 简写为 -t.
  • ‘lib=s’     => @libs    如果相关联的变量是个数组, 如这个地方的 @libs, 那么选项可以多次出现, 值可以被推到数组里.
  • ‘flag=s’    => %flags  如果相关联的变量是个散列, 那么就要求一个键=值(key=value)对, 并被插入到散列里.

备注:
     在匹配参数名的时候,GetOptions 在缺省设置下会忽略大小写,默认参数被简写为唯一的最短字符串(首字母)(例如,-m 代表 -more. 相同的首字母时,会加上第二个字母来区分)

Getopt 模块的程序使用的方法:

根据上面的例子,比如我们写了一个程序叫 test.pl .我们只需要在命令行中加如下参数:
$ ./test.pl  --verbose --verbose -v --more \
      --lib=‘/lib‘ -l ‘/lib64‘ --f a=1 --flag b=2  --debug 2 -t fukai

有点小长,在看看上面的,就会明白意思了。在这个地方,我使用了 Smart::Comment 模块,所以在最下面的 ###  是会输出这个变量本身的内容的。这也是一个超级强大的模块。我们来看看输入这些参数后。会输出什么内容吧。
### $verbose: 3
### $more: 1
### $debug: 2
### @libs: [
###          ‘/lib‘,
###          ‘/lib64‘
###        ]
### %flags: {
###           a => ‘1‘,
###           b => ‘2‘
###         }


在对一下上面输入的参数,明白了吧。

 

Getopt 模块的简单总结

(1. 带值参数传入程序内部
※参数类型:整数, 浮点数, 字串
Getoptions(

‘tag=s‘ =>\$tag

);

‘=’表示此参数一定要有参数值, 若改用’:‘代替表示参数不一定要有参数值
‘s’表示传递字串参数, 若为’i‘表传递整数参数, 若为’f‘表传递浮点数.
带值参数使用的方法

$ test.pl --tag=string

$ test.pl --tag string

(2. 需要传送多个值的参数到程序中.
比如需要传几个值到 @libfiles 中的操作方法。

GetOptions ("library=s" => \@libfiles);

GetOptions ("library=s@" => \$libfiles);

参数传到 @$tag
使用的方法

$ test.pl --library lib/stdlib --library lib/extlib

(3. 对键值对的参数传递
有时我们需要传送一些键值对到程序中进行处理,就需要使用到这个功能了.

GetOptions ("define=s" => \%defines);

GetOptions ("define=s%" => \$defines);
使用的方法

$ test.pl --define os=linux --define vendor=redhat

  (4. 参数的别名
我们需要参数加个简写之类的别名时,可以使用下面的方法

GetOptions (‘length|height=f‘ => \$length);

第一个名称为 primary name, 其他的名称为 alias(可有多个alias名称) ,当使用hash参数时, 使用primary name作为key值。