PHP在cli模式下接收參數(shù)有兩種方法
1.使用argv數(shù)組
2.使用getopt方法
1.使用argv數(shù)組
例如:需要執(zhí)行一個(gè)php,并傳遞三個(gè)參數(shù)(type=news, is_hot=1, limit=5)
創(chuàng)建test.php
<?php print_r($argv); ?>
在命令行執(zhí)行
php test.php news 1 5
輸出:
Array ( [0] => test.php [1] => news [2] => 1 [3] => 5 )
可以看到argv[0]為當(dāng)前執(zhí)行的php文件名稱,而argv[1]~argv[3]則是傳遞的參數(shù)的值
argv[1]等于type的值
argv[2]等于is_hot的值
argv[3]等于limit的值
這樣可以根據(jù)argv數(shù)組來(lái)獲取傳遞的參數(shù)進(jìn)行后續(xù)的處理操作。
缺點(diǎn):
使用argv數(shù)組,可以按順序獲取傳遞的參數(shù)。但獲取后,需要做一個(gè)對(duì)應(yīng)處理,上例中需要把a(bǔ)rgv[1]對(duì)應(yīng)type參數(shù),argv[2]對(duì)應(yīng)is_hot參數(shù),argv[3]對(duì)應(yīng)limit參數(shù)。而如果在傳遞的過(guò)程中,參數(shù)順序?qū)戝e(cuò),則會(huì)導(dǎo)致程序出錯(cuò)。
例如:
<?php $param = array(); $param['type'] = $argv[1]; $param['is_hot'] = $argv[2]; $param['limit'] = $argv[3]; print_r($param); ?>
執(zhí)行
php test.php news 1 5
輸出:
Array ( [type] => news [is_hot] => 1 [limit] => 5 )
而傳遞順序不同,獲取到的參數(shù)數(shù)值會(huì)不同,導(dǎo)致后續(xù)程序出錯(cuò)
執(zhí)行
php test.php 1 5 news
輸出:
Array ( [type] => 1 [is_hot] => 5 [limit] => news )
因此在使用argv數(shù)組傳遞參數(shù)時(shí),需要注意參數(shù)傳遞的順序。
2.使用getopt方法
getopt 從命令行參數(shù)列表中獲取選項(xiàng)
array getopt ( string $options [, array $longopts ] )
參數(shù):
options
該字符串中的每個(gè)字符會(huì)被當(dāng)做選項(xiàng)字符,匹配傳入腳本的選項(xiàng)以單個(gè)連字符(-)開頭。 比如,一個(gè)選項(xiàng)字符串 “x” 識(shí)別了一個(gè)選項(xiàng) -x。 只允許 a-z、A-Z 和 0-9。
longopts
選項(xiàng)數(shù)組。此數(shù)組中的每個(gè)元素會(huì)被作為選項(xiàng)字符串,匹配了以兩個(gè)連字符(–)傳入到腳本的選項(xiàng)。 例如,長(zhǎng)選項(xiàng)元素 “opt” 識(shí)別了一個(gè)選項(xiàng) –opt。
options 可能包含了以下元素:
單獨(dú)的字符(不接受值)
后面跟隨冒號(hào)的字符(此選項(xiàng)需要值)
后面跟隨兩個(gè)冒號(hào)的字符(此選項(xiàng)的值可選)
選項(xiàng)的值是字符串后的第一個(gè)參數(shù)。它不介意值之前是否有空格。
options 和 longopts 的格式幾乎是一樣的,唯一的不同之處是 longopts 需要是選項(xiàng)的數(shù)組(每個(gè)元素為一個(gè)選項(xiàng)),而 options 需要一個(gè)字符串(每個(gè)字符是個(gè)選項(xiàng))。
傳值的分隔符可以使用空格或=。
可選項(xiàng)的值不接受空格作為分隔符,只能使用=作為分隔符。
返回值
此函數(shù)會(huì)返回選項(xiàng)/參數(shù)對(duì),失敗時(shí)返回 FALSE。
選項(xiàng)的解析會(huì)終止于找到的第一個(gè)非選項(xiàng),之后的任何東西都會(huì)被丟棄。
1.使用options實(shí)例
a,b,c 為需要值
d 為可選值
e 為不接受值
<?php $param = getopt('a:b:c:d::e'); print_r($param); ?>
執(zhí)行
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實(shí)例
type,is_hot 為需要值
limit 為可選值
expire 為不接受值
<?php $longopt = array( 'type:', 'is_hot:', 'limit::', 'expire' ); $param = getopt('', $longopt); print_r($param); ?>
執(zhí)行
php test.php --type news --is_hot 1 --limit=10 --expire=100
輸出:
Array ( [type] => news [is_hot] => 1 [limit] => 10 [expire] => )