在 Perl 中使用 Getopt::Long 模組來接收使用者命令列參數 z

來源:互聯網
上載者:User

轉載本站文章請註明,轉載自: 扶凱[http://www.php-oa.com]

本文連結:

http://www.php-oa.com/2009/04/04/perl_getopt-long.html

 我們在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'
###         }

<span style="font-size:18px"><span style="font-family:Arial,Verdana,sans-serif"><span style="white-space:normal">在對一下上面輸入的參數,明白了吧。</span></span></span>

 

Getopt 模組的簡單總結

(1. 帶值參數傳入程式內部
※參數類型:整數, 浮點數, 字串
Getoptions(

'tag=s' =>\$tag

);

‘=’表示此參數一定要有參數值, 若改用’:'代替表示參數不一定要有參數值
‘s’表示傳遞字串參數, 若為’i'表傳遞整數參數, 若為’f'表傳遞浮點數.
帶值參數使用的方法

$ test.pl --tag=string

<span style="font-size:18px">$ test.pl --tag string</span>

(2. 需要傳送多個值的參數到程式中.
比如需要傳幾個值到 @libfiles 中的操作方法。

<span style="font-size:18px">GetOptions ("library=s" =&gt; \@libfiles); GetOptions ("library=s@" =&gt; \$libfiles);</span>

參數傳到 @$tag
使用的方法

<span style="font-size:18px">$ test.pl --library lib/stdlib --library lib/extlib</span>

(3. 對索引值對的參數傳遞
有時我們需要傳送一些索引值對到程式中進行處理,就需要使用到這個功能了.

<span style="font-size:18px">GetOptions ("define=s" =&gt; \%defines);</span>

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

使用的方法

<span style="font-size:18px">$ test.pl --define os=linux --define vendor=redhat</span>

  (4. 參數的別名
我們需要參數加個簡寫之類的別名時,可以使用下面的方法

<span style="font-size:18px">GetOptions ('length|height=f' =&gt; \$length);</span>

第一個名稱為 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.