PHP 中經過 getopt 解析 GNU C 風格命令行選項

在 PHP 中,當咱們在獲取命令行參數時,能夠經過遍歷$argv來獲取,其實呢是有規範可循的,也就是 GNU C-style parser for command line options 。php

好比使用命令wget下載文件時,使用下面的一些方式來指定option均可以linux

wget http://mengkang.net/a.jpg -O b.jpg
wget http://mengkang.net/a.jpg -Ob.jpg --tries=3 -b
wget http://mengkang.net/a.jpg -Ob.jpg --tries=3 -bvd

咱們整理下command line options的規則,首先參數分爲短參數名和完整參數名,並且一些還有映射關係。好比咱們使用wget時,-O對應--output-document數組

總結 options 使用規範

  • 短參數名,有一個限制,只能是一個char字符,只能1字節,不能超過1字節,好比上面的第四個命令的最後一個參數就不知道是一個參數仍是三個參數了。
  • 短參數名用單個連字符(-)開始
  • 短參數能夠一個-後面跟多個參數名
  • 長參數名,則是多字節的的,兩個連字符(--)開始
  • 行參與實參之間,能夠直接鏈接,也能夠用空格隔開,還能夠用等號鏈接
  • 參數分爲沒有值,必須傳值,可選傳值(也就是可傳可不傳)

在 PHP 中的使用

getopt ( string $options [, array $longopts [, int &$optind ]] ) : array
https://www.php.net/manual/zh...
$options 短參數字符列表,參數字符後面用 :標識必須傳值;參數字符後面用 ::標識可選傳值;只有參數字符表示該參數(或者說選項)不接受傳值
$longopts 長參數因爲是多字節,因此必須是數組,不然無法分隔。長參數一樣遵循上面 :::規則

php裏面缺乏結構體的支撐,相比c的長選項的配置更加簡潔,但也缺乏了長短選項的映射關係配置。bash

$shortOpts = "O:Vv::dh";
$longOpts = ["output-document:","version","verbose::", "debug", "help"]; 
$options = getopt($shortOpts, $longOpts);

var_export($options);
php getopt.php -Oa.jpg 
array (
  'O' => 'a.jpg',
)
php getopt.php -O=a.jpg
array (
  'O' => 'a.jpg',
)
php getopt.php -O a.jpg                                 
array (
  'O' => 'a.jpg',
)
php getopt.php -O=a.jpg -dhV
array (
  'O' => 'a.jpg',
  'd' => false,
  'h' => false,
  'V' => false,
)
php getopt.php -O=a.jpg -dhV -vvv
array (
  'O' => 'a.jpg',
  'd' => false,
  'h' => false,
  'V' => false,
  'v' => 'vv',
)

上面例子中個人短參數和長參數是對應的,可是沒有數據結構來表示他們的對應關係(在C裏面有option結構體來作這個對應關係的管理),因此咱們兩個都傳的話,程序兩個值會收到,而後咱們本身判斷短參數和長參數使用哪一個。數據結構

php getopt.php -O=a.jpg -dhV -vvv --output-document b.jpg --debug
array (
  'O' => 'a.jpg',
  'd' => false,
  'h' => false,
  'V' => false,
  'v' => 'vv',
  'output-document' => 'b.jpg',
  'debug' => false,
)

這樣寫是不規範的,儘可能避免這樣的寫法。工具

php getopt.php -O=a.jpg -dhVvvv  
array (
  'O' => 'a.jpg',
  'd' => false,
  'h' => false,
  'V' => false,
  'v' => 'vv',
)
php getopt.php -O=a.jpg -dhvvvV
array (
  'O' => 'a.jpg',
  'd' => false,
  'h' => false,
  'v' => 'vvV',
)

總結了這個GNU C command line options 使用的套路,命令使用起來就更溜了,不會懵逼爲何linux下各類工具使用的案例寫法「千奇百怪」了。.net

在C裏面並不支持 短選項用等號鏈接,在PHP裏倒是能夠的,須要注意。
相關文章
相關標籤/搜索