php cli模式下獲取引數的方法
php在cli模式下接收引數有兩種方法
1.使用argv陣列
2.使用getopt方法
1.使用argv陣列
例如:需要執行一個php,並傳遞三個引數(type=news, is_hot=1, limit=5)
建立test.php
<?php
print_r($argv);
?>
在命令列執行
php test.php news 1 5
輸出:
Array
(
[0] => test.php
[1] => news
[2] => 1
[3] => 5
)
可以看到argv[0]為當前執行的php檔名稱,而argv[1]~argv[3]則是傳遞的引數的值
argv[1]等於type的值
argv[2]等於is_hot的值
argv[3]等於limit的值
這樣可以根據argv陣列來獲取傳遞的引數進行後續的處理操作。
缺點:
使用argv陣列,可以按順序獲取傳遞的引數。但獲取後,需要做一個對應處理,上例中需要把argv[1]對應type引數,argv[2]對應is_hot引數,argv[3]對應limit引數。而如果在傳遞的過程中,引數順序寫錯,則會導致程式出錯。
例如:
<?php
$param = array();
$param['type'] = $argv[1];
$param['is_hot'] = $argv[2];
$param['limit'] = $argv[3];
print_r($param);
?>
執行
php test.php news 1 5
輸出:
Array
(
[type] => news
[is_hot] => 1
[limit] => 5
)
而傳遞順序不同,獲取到的引數數值會不同,導致後續程式出錯
執行
php test.php 1 5 news
輸出:
Array
(
[type] => 1
[is_hot] => 5
[limit] => news
)
因此在使用argv陣列傳遞引數時,需要注意引數傳遞的順序。
2.使用getopt方法
getopt 從命令列引數列表中獲取選項
array getopt ( string $options [, array $longopts ] )
引數:
options
該字串中的每個字元會被當做選項字元,匹配傳入指令碼的選項以單個連字元(-)開頭。 比如,一個選項字串 “x” 識別了一個選項 -x。 只允許 a-z、A-Z 和 0-9。
longopts
選項陣列。此陣列中的每個元素會被作為選項字串,匹配了以兩個連字元(–)傳入到指令碼的選項。 例如,長選項元素 “opt” 識別了一個選項 –opt。
options 可能包含了以下元素:
單獨的字元(不接受值)
後面跟隨冒號的字元(此選項需要值)
後面跟隨兩個冒號的字元(此選項的值可選)
選項的值是字串後的第一個引數。它不介意值之前是否有空格。
options 和 longopts 的格式幾乎是一樣的,唯一的不同之處是 longopts 需要是選項的陣列(每個元素為一個選項),而 options 需要一個字串(每個字元是個選項)。
傳值的分隔符可以使用空格或=。
可選項的值不接受空格作為分隔符,只能使用=作為分隔符。
返回值
此函式會返回選項/引數對,失敗時返回 FALSE。
選項的解析會終止於找到的第一個非選項,之後的任何東西都會被丟棄。
1.使用options例項
a,b,c 為需要值
d 為可選值
e 為不接受值
<?php
$param = getopt('a:b:c:d::e');
print_r($param);
?>
執行
php test.php -a 1 -b 2 -c 3 -d=4 -e 5
輸出:
Array
(
[a] => 1
[b] => 2
[c] => 3
[d] => 4
[e] =>
)
2.使用longopts例項
type,is_hot 為需要值
limit 為可選值
expire 為不接受值
<?php
$longopt = array(
'type:',
'is_hot:',
'limit::',
'expire'
);
$param = getopt('', $longopt);
print_r($param);
?>
執行
php test.php --type news --is_hot 1 --limit=10 --expire=100
輸出:
Array
(
[type] => news
[is_hot] => 1
[limit] => 10
[expire] =>
)
3.找到第一非選項,後面忽略例項
<?php
$longopt = array(
'type:',
'is_hot:',
'limit::',
'expire'
);
$param = getopt('', $longopt);
print_r($param);
?>
執行
php test.php --type news --is_hots 1 --limit=10 --expire=100
輸出:
Array
(
[type] => news
)
因為is_hots不是選項值(定義的是is_hot),所以從這裡開始之後的引數,都被丟棄。
總結:
使用argv陣列傳引數,方法簡單,實現方便。引數的順序不能錯,引數獲取後需要做對應處理。
使用getopt方法,可使用引數名,引數順序可隨意,比較規範。(建議使用)