- 
                Notifications
    You must be signed in to change notification settings 
- Fork 48
input instance
        Inhere edited this page Jan 10, 2019 
        ·
        2 revisions
      
    输入对象是 Inhere\Console\IO\Input 的实例,创建 console 应用时,内部会自动创建一个 input 实例。
你也可以单独的
new Inhere\Console\IO\Input, 来使用它解析命令行参数等功能。
在终端中执行如下命令,用于演示参数选项等信息的解析:
$ php examples/app home:useArg status=2 name=john arg0 -s=test --page=23 --id=154 -e dev -v vvv -d -rf --debug --test=false一点说明:
- 没有 -开头的都认为是参数 (eg:status=2arg0)
- 反之,以 -开头的则是选项数据- 
--开头的是长选项(long-option)
- 一个 -开头的是短选项(short-option)
 
- 
支持混合式选项的赋值
--id=154和--id 154是等效的
注意: 输入如下的字符串将会认为是布尔值
- 
on|yes|true--true
- 
off|no|false--false
echo $input->getScript();   // 'examples/app' 执行的入口脚本文件
echo $input->getCommand(); // 'home:useArg' 解析到的第一个参数将会被认为是命令名称,并且不会再存入到 参数列表中
echo $input->getFullScript(); // 命令行输入的原样字符串通常的参数如
arg0只能根据 index key 来获取值。但是提供以等号(=)连接的方式来指定参数名(eg:status=2)
打印所有的参数信息:
var_dump($input->getArgs());output:
array(3) {
  'status' => string(1) "2"
  'name' => string(4) "john"
  [0] => string(4) "arg0"
}// argument
$first = $input->getFirstArg(); // 'arg0'
$status = $input->get('status', 'default value'); // '2'获取解析后的选项信息
- 没有值的选项,将设置默认值为 bool(true)
- 短选项不仅仅只是以一个 -开头,而且名称 只能是一个字符
- 多个(默认值的)短选项可以合并到一起写。如 -rf会被解析为两个短选项'r' => bool(true)'f' => bool(true)
打印所有的选项信息:
var_dump($input->getOpts());
// var_dump($input->getLOpts()); // 只打印长选项信息
// var_dump($input->getSOpts()); // 只打印短选项信息output:
array(10) {          
  's' => string(4) "test"   
  'e' => string(3) "dev"    
  'v' => string(3) "vvv"    
  'd' => bool(true)         
  'r' => bool(true)         
  'f' => bool(true)         
  'page' => string(2) "23"     
  'id' =>   string(3) "154"    
  'debug' => bool(true)         
  'test' => bool(false)        
}// option
$page = $input->getOpt('page') // '23'
$debug = $input->boolOpt('debug') // True
$test = $input->boolOpt('test') // False
$d = $input->boolOpt('d') // True
$d = $input->sBoolOpt('d') // True
// 获取到一个值就返回,对同一个含义的选项选项非常有用
$showHelp = $input->sameOpt(['h','help']) echo "Your name:";
$name = $input->read(); 
echo 'input is ' . $name; // 'simon'效果(in terminal):
$ Your name: simon
$ input is simon
也可以直接将消息文本放入参数 $name = $input->read("Your name:");
我的其他PHP项目
- inhere/kite 方便本地开发和使用的个人CLI工具应用
- php-toolkit/pflag PHP编写的,通用的命令行标志(选项和参数)解析库
- phppkg/easytpl 使用简单且快速的 PHP 模板引擎
- inhere/php-validate 一个简洁小巧且功能完善的php验证库
- inhere/sroute 轻量且快速的HTTP请求路由库