欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

PHP使用getopt()解析cli参数

程序员文章站 2022-03-21 20:41:07
PHP手册的getopt()介绍如下: /** * Gets options from the command line argument list * @link http://php.net/manual/en/function.getopt.php * @param string $optio ......

PHP手册的getopt()介绍如下:

/**

* Gets options from the command line argument list

* @link http://php.net/manual/en/function.getopt.php

* @param string $options Each character in this string will be used as option characters and

* matched against options passed to the script starting with a single

* hyphen (-).

* For example, an option string "x" recognizes an

* option -x.

* Only a-z, A-Z and 0-9 are allowed.

* @param array $longopts [optional] An array of options. Each element in this array will be used as option

* strings and matched against options passed to the script starting with

* two hyphens (--).

* For example, an longopts element "opt" recognizes an

* option --opt.

* Prior to PHP5.3.0 this parameter was only available on few systems

* @param int $optind If the optind parameter is present, then the index where argument parsing stopped will be written to this variable.

* @return array This function will return an array of option / argument pairs or false on

* failure.

* @since 4.3.0

* @since 5.0

*/

function getopt ($options, array $longopts = null, &$optind = null) {}

 

$options :字符串类型,其中每个字符被当作选项字符,匹配传入脚本的选项以单个连字符(-)开头。比如,一个选项字符串 "x" 识别了一个选项 -x。 只允许 a-z、A-Z 和 0-9。

字符参数后面可以:

没有冒号(比如:h):不需要提供value,有提供也不会读取,用来判断有没有设置了这个参数。 有一个冒号(比如:p:):需要提供value,没有提供value就不读取这个参数。可以按这几种方式来设置值:-p 123,–p123,-p=123。 有两个冒号(比如:f::):value是可选的,有没有设置value都读取(没有设置时读取的value为false),value需要连在参数后面,不能用空格分隔开。可以按这几种方式来设置值:-f=123,-f123。

$longopts :数组类型,此数组中的每个元素会被作为选项字符串,匹配了以两个连字符(--)传入到脚本的选项。 例如,长选项元素 "opt" 识别了一个选项 --opt。

$options和$longopts的格式几乎是一样的,唯一的不同之处是$longopts需要是选项的数组(每个元素为一个选项),而$options需要一个字符串(每个字符是个选项)。