在Perl中使用Getopt::Long模組來接收使用者命令列參數_應用技巧

來源:互聯網
上載者:User

我們在linux常常用到一個程式需要加入參數,現在瞭解一下 perl 中的有關控制參數的模組 Getopt::Long ,比直接使用 @ARGV 的數組強大多了.我想大家知道在 Linux 中有的參數有二種形式.

•長參數  –help
•短參數   -h
也就是-和–的分別.–表示完整參數.-表示簡化參數.在 Perl 的這個模組中也支援這二種方法.
這要介紹的二 Getopt 其實有二個模組,一個叫 Getopt::Long 一個叫 Getopt::Std.下面就只介紹 Getopt::Long 了.因為這個模組更加強大

Getopt::Long 模組
初始化 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
### $more
### $debug
### $test
### @libs;
### %flags

這就是使用的方法,下面是詳細解釋,注意看 GetOptions 中的 => 前面的部分.下面是詳解

•‘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值

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.