찾다
백엔드 개발PHP 튜토리얼PHP를 사용하여 명령줄 애플리케이션을 빠르게 구축하는 방법


당신이 개발 엔지니어라면 PHP를 사용하여 많은 애플리케이션을 개발했을 것입니다. 하지만 PHP를 사용하여 명령줄 애플리케이션(도구)을 빠르게 구축하는 방법을 알고 계십니까? 아래에서는 PHP와 유명한 Composer 확장 패키지--Symphony/Console은 명령줄 애플리케이션을 빌드합니다. <code>Web开发工程师,那么你一定使用PHP开发过很多Web应用程序。但是你知道如何使用PHP快速构建一个命令行应用程序(工具)吗?下面我将向您展示如何使用PHP和一个著名的的Composer扩展包--Symphony/Console构建一个命令行应用。

Symphony/Console是一个使用Composer管理的PHP扩展包,它简化了创建一个漂亮的、可测试的PHP命令行应用的过程,它提供了开箱即用的诸如(可选/必选的)参数规范和选项规范(使用-符号)等功能。那么,我们来一起开始构建我们的应用。

按照惯例,我们将构建一个“Hello World”的控制台应用程序,但是要稍微修改一下它,让它支持自定义问候语(代替Hello),并且可以随意的去问候一个人(代替world)。

这个Hello World应用程序将会有如下功能:

  1. 为我们提供一个单独的greet(问候)命令,我们将使用它来与应用程序交互。

  2. greet可以接受一个可选的参数(name)来打印出一个被问候的人(默认是World)。

  3. greet可以接受一个选项(--say)来更改问候语(默认是Hello)。

  4. 如果我们么样给定参数或者选项,程序将默认输出一个Hello World消息。

如何使用PHP构建命令行应用程序

  • 为我们的项目创建新的目录并cd进入它:

    mkdir hello-world-app && cd hello-world-app
  • 使用Composer将控制台组件引入我们项目

    composer require symfony/console
  • 然后为你的应用程序创建一个入口点,PHP扩展不是必需的,因为我们要使这个文件成为可执行文件,并在文件本身中指定环境。

    touch HelloWorld
    chmod +X HelloWorld
  • 将下面的代码添加到HelloWorld文件中(后面我将为每一行做注解),并在你的终端中执行HelloWorld这个应用程序.

    #!/usr/bin/env php
    <?php require __DIR__.&#39;/vendor/autoload.php&#39;;
    
    use Symfony\Component\Console\Application;
    use Symfony\Component\Console\Input\InputArgument;
    use Symfony\Component\Console\Input\InputInterface;
    use Symfony\Component\Console\Input\InputOption;
    use Symfony\Component\Console\Output\OutputInterface;
    
    (new Application(&#39;Hello World&#39;, &#39;1.0.0&#39;))
          ->register('greet')
          ->addArgument('name', InputArgument::OPTIONAL, 'Name of the person')
          ->addOption('say', null, InputOption::VALUE_REQUIRED, 'Custom greeting')
          ->setCode(function (InputInterface $input, OutputInterface $output) {
                  
            $name = $input->getArgument('name');
            $greeting = $input->getOption('say');
    
            if (!empty($name) && !empty($greeting)) {
                return $output->writeln("<info>$greeting $name!</info>");
            } else if (!empty($name)) {
                return $output->writeln("<info>Hello $name!</info>");
            } else if (!empty($greeting)) {
                return $output->writeln("<info>$greeting World!</info>");
            } else {
                return $output->writeln("<info>Hello World!</info>");
            }
          })
          ->getApplication()
          ->run();

看,就这样,你拥有了自己的HelloWorld控制台程序
PHP를 사용하여 명령줄 애플리케이션을 빠르게 구축하는 방법
当没有指定命令时,HelloWorld默认输出一屏信息提示

Symfony Console组件给我们提供的应用程序有几个开箱可用的选项的和命令,比如helplist--version

解释这个神奇的文件内容

OK,让我们来看看我们的HelloWorld文件中的代码。

  1. 我们引入autoload.php以使用由composer提供的自动加载以及控制台组件提供的各功能。

InputInterfaceOutputInterface将使应用程序的输入和输出功能变得简单,InputArgumentInputOption将帮助我们处理传递给我们HelloWorld应用程序的选项和参数。

require __DIR__.'/vendor/autoload.php'; 

use Symfony\Component\Console\Application; 
use Symfony\Component\Console\Input\InputArgument; 
use Symfony\Component\Console\Input\InputInterface; 
use Symfony\Component\Console\Input\InputOption; 
use Symfony\Component\Console\Output\OutputInterface;
  1. symphony/console通过名称实例化一个新的应用程序HelloWorld (v1.0.0) ,并注册我们的greet命令。

    (new Application('Hello World', '1.0.0'))
        ->register('greet')
  2. 我们添加一个可选的name参数(addArgument()),并提供参数的简短描述。然后,我们使用这个addOption()方法添加一个say选项。请注意,选项始终是可选的,但您可以指定要传递的值,也可以仅仅将其用作指boolean标识。

    ->addArgument('name', InputArgument::OPTIONAL, 'Name of the person') 
    ->addOption('say', null, InputOption::VALUE_REQUIRED, 'Custom greeting')
  3. setCode()方法中的代码会包含我们应用程序的主逻辑,它会根据传递的参数和选项打印一个问候语到终端。我们监听$input对象,使用getArgument()getOption()辅助方法获取传递给greet的选项和参数,然后,我们只需要检查传递了哪些参数或者选项,并相应的(使用$output对象)向控制台输出打印问候语。这个writeln()方法可以根据标签格式化文本,比如输出不同颜色的info,errorwarning

    ->setCode(function (InputInterface $input, OutputInterface $output) {
        $name = $input->getArgument('name');
        $greeting = $input->getOption('say');
    
        if (!empty($name) && !empty($greeting)) {
            return $output->writeln("<info>$greeting $name!</info>");
        } else if (!empty($name)) {
            return $output->writeln("<info>Hello $name!</info>");
        } else if (!empty($greeting)) {
            return $output->writeln("<info>$greeting World!</info>");
        } else {
            return $output->writeln("<info>Hello World!</info>");
        }
      })
  4. 最后我们引导应用程序并调用他的方法,以便他做好随时接收和处理greet命令。

    ->getApplication()
    ->run();

现在让我们在实例中看看我们HelloWorld程序

  1. greet

    Symphony/Console은 Composer로 관리되는 PHP 확장 패키지로, 아름답고 테스트 가능한 PHP 명령줄 생성을 단순화합니다. 애플리케이션 프로세스는 다음을 제공합니다. (선택적/필수) 매개변수 사양 및 옵션 사양(- 기호 사용)과 같은 기본 기능입니다. 이제 함께 애플리케이션 구축을 시작하겠습니다.
평소처럼 "Hello World" 콘솔 애플리케이션을 구축할 예정이지만 (Hello 대신) 사용자 정의 인사말을 지원하고 (World 대신) 마음대로 사람에게 인사할 수 있도록 약간 수정합니다.

이 Hello World 애플리케이션에는 다음 기능이 있습니다:

  1. 별도의 인사( 인사말)를 제공하세요. 애플리케이션과 상호 작용하는 데 사용할 명령입니다. PHP를 사용하여 명령줄 애플리케이션을 빠르게 구축하는 방법
  2. greet는 선택적 매개변수(name)를 사용하여 인사받는 사람을 인쇄할 수 있습니다(기본값은 World). 🎜🎜
  3. 🎜greet는 옵션(--say)을 사용하여 인사말을 변경할 수 있습니다(기본값은 Hello). 🎜🎜
  4. 🎜매개변수나 옵션을 제공하면 프로그램은 기본적으로 Hello World 메시지를 출력합니다. 🎜🎜🎜

    PHP를 사용하여 명령줄 애플리케이션을 구축하는 방법

    • 🎜프로젝트와 cd를 위한 새 디렉터리를 만듭니다. >들어가세요: 🎜
      mkdir hello-world-app && cd hello-world-app
      🎜
    • 🎜Composer를 사용하여 콘솔 구성 요소를 프로젝트로 가져옵니다. 🎜
      composer require symfony/console
      🎜
    • 🎜 그런 다음 애플리케이션에 대한 진입점을 만듭니다. 우리가 만들 예정이므로 PHP 확장은 필요하지 않습니다. 이 파일은 실행 파일이 되어 파일 자체에 환경을 지정합니다. 🎜
      touch HelloWorld
      chmod +X HelloWorld
      🎜
    • 🎜 HelloWorld 파일에 다음 코드를 추가하고(나중에 각 줄에 주석을 달겠습니다) 터미널 애플리케이션에서 HelloWorld를 실행하세요.🎜
      #!/usr/bin/env php
      <?php require __DIR__.&#39;/vendor/autoload.php&#39;;
      
      use Symfony\Component\Console\Application;
      use Symfony\Component\Console\Input\InputArgument;
      use Symfony\Component\Console\Input\InputInterface;
      use Symfony\Component\Console\Input\InputOption;
      use Symfony\Component\Console\Output\OutputInterface;
      
      (new Application(&#39;Hello World&#39;, &#39;1.0.0&#39;))
            ->register('greet')
            ->addArgument('name', InputArgument::OPTIONAL, 'Name of the person')
            ->addOption('say', null, InputOption::VALUE_REQUIRED, 'Custom greeting')
            ->setCode(function (InputInterface $input, OutputInterface $output) {
                    
              $name = $input->getArgument('name');
              $greeting = $input->getOption('say');
      
              if (!empty($name) && !empty($greeting)) {
                  return $output->writeln("<info>$greeting $name!</info>");
              } else if (!empty($name)) {
                  return $output->writeln("<info>Hello $name!</info>");
              } else if (!empty($greeting)) {
                  return $output->writeln("<info>$greeting World!</info>");
              } else {
                  return $output->writeln("<info>Hello World!</info>");
              }
            })
            ->getApplication()
            ->run();
      🎜🎜자, 그게 다입니다. 여러분만의 HelloWorld 콘솔 프로그램이 생겼습니다🎜🎜PHP를 사용하여 명령줄 애플리케이션을 빠르게 구축하는 방법🎜🎜명령이 지정되지 않으면 HelloWorld는 기본적으로 정보 화면을 출력합니다.🎜🎜Symfony Console 구성 요소는 애플리케이션을 제공합니다. help, list--version과 같은 상자🎜

      이 마법의 파일 콘텐츠에 대해 설명

      🎜좋아요. HelloWorld 파일의 코드를 살펴보세요. 🎜
      1. 🎜 composer에서 제공하는 자동 로딩과 콘솔 컴포넌트의 각 기능을 사용할 수 있도록 autoload.php를 소개합니다. 🎜🎜🎜🎜InputInterfaceOutputInterface는 애플리케이션의 입력 및 출력 기능을 단순하게 만들고, InputArgumentInputOption은 HelloWorld 애플리케이션에 전달된 옵션과 매개변수를 처리하는 데 도움을 주세요. 🎜
        require __DIR__.'/vendor/autoload.php'; 
        
        use Symfony\Component\Console\Application; 
        use Symfony\Component\Console\Input\InputArgument; 
        use Symfony\Component\Console\Input\InputInterface; 
        use Symfony\Component\Console\Input\InputOption; 
        use Symfony\Component\Console\Output\OutputInterface;
        1. 🎜symphony/console이름HelloWorld(v1.0.0) 으로 새 애플리케이션을 인스턴스화하고 등록합니다. 인사 명령을 내리세요. 🎜
          (new Application('Hello World', '1.0.0'))
              ->register('greet')
          🎜
        2. 🎜선택적인 name 매개변수(addArgument())를 추가하고 매개변수에 대한 간단한 설명을 제공합니다. 그런 다음 이 addOption() 메서드를 사용하여 say 옵션을 추가합니다. 옵션은 항상 선택 사항이지만 전달할 값을 지정하거나 부울 식별자에 대한 참조로 사용할 수 있습니다. 🎜
          ->addArgument('name', InputArgument::OPTIONAL, 'Name of the person') 
          ->addOption('say', null, InputOption::VALUE_REQUIRED, 'Custom greeting')
          🎜
        3. 🎜 setCode() 메소드의 코드에는 전달된 매개변수와 옵션에 따라 터미널에 인사말을 인쇄하는 애플리케이션의 기본 로직이 포함됩니다. $input 객체를 수신하고 getArgument()getOption() 도우미 메서드를 사용하여 greet에 전달된 옵션을 얻습니다. 및 매개변수를 사용하여 전달된 매개변수 또는 옵션을 확인하고 그에 따라 인사말을 콘솔에 인쇄하면 됩니다($output 개체 사용). 이 writeln() 메서드는 정보, 오류경고의 다양한 색상을 출력하는 등 태그에 따라 텍스트 형식을 지정할 수 있습니다. > . 🎜
          ->setCode(function (InputInterface $input, OutputInterface $output) {
              $name = $input->getArgument('name');
              $greeting = $input->getOption('say');
          
              if (!empty($name) && !empty($greeting)) {
                  return $output->writeln("<info>$greeting $name!</info>");
              } else if (!empty($name)) {
                  return $output->writeln("<info>Hello $name!</info>");
              } else if (!empty($greeting)) {
                  return $output->writeln("<info>$greeting World!</info>");
              } else {
                  return $output->writeln("<info>Hello World!</info>");
              }
            })
          🎜
        4. 🎜마지막으로 애플리케이션을 부트스트랩하고 메서드를 호출하여 언제든지 greet 명령을 수신하고 처리할 수 있도록 준비합니다. 🎜
          ->getApplication()
          ->run();
          🎜🎜

          이제 HelloWorld 프로그램의 예를 살펴보겠습니다.

          1. 🎜greet가 통과하지 못했습니다. 모든 매개변수 및 옵션 🎜🎜🎜🎜🎜🎜🎜🎜
            1. greet에는 선택적 name 매개변수가 있습니다greet有一个可选的name参数

            PHP를 사용하여 명령줄 애플리케이션을 빠르게 구축하는 방법

            1. greet使用say选项自定义问候语

            PHP를 사용하여 명령줄 애플리케이션을 빠르게 구축하는 방법

            1. 最后,greet自定义问候语和问候人

            PHP를 사용하여 명령줄 애플리케이션을 빠르게 구축하는 방법


            关于作者

            程序开发人员,不拘泥于语言与技术,目前主要从事PHP和前端开发,使用Laravel和VueJs。合适和够用是永不停息的追求。

            个人网站:https://www.linganmin.cn

            译者注:本文中的部分链接和图片地址已更换为国内地址,如有翻译错误请多指正。
            Happy Coding!


            原文地址:How to build a Command Line Application using PHP?

            如果你是一名Web开发工程师,那么你一定使用PHP开发过很多Web应用程序。但是你知道如何使用PHP快速构建一个命令行应用程序(工具)吗?下面我将向您展示如何使用PHP和一个著名的的Composer扩展包--Symphony/Console构建一个命令行应用。

            Symphony/Console是一个使用Composer管理的PHP扩展包,它简化了创建一个漂亮的、可测试的PHP命令行应用的过程,它提供了开箱即用的诸如(可选/必选的)参数规范和选项规范(使用-符号)等功能。那么,我们来一起开始构建我们的应用。

            按照惯例,我们将构建一个“Hello World”的控制台应用程序,但是要稍微修改一下它,让它支持自定义问候语(代替Hello),并且可以随意的去问候一个人(代替world)。

            这个Hello World应用程序将会有如下功能:

            1. 为我们提供一个单独的greet(问候)命令,我们将使用它来与应用程序交互。

            2. greet可以接受一个可选的参数(name)来打印出一个被问候的人(默认是World)。

            3. greet可以接受一个选项(--say)来更改问候语(默认是Hello)。

            4. 如果我们么样给定参数或者选项,程序将默认输出一个Hello World消息。

            如何使用PHP构建命令行应用程序

            • 为我们的项目创建新的目录并cd进入它:

              mkdir hello-world-app && cd hello-world-app
            • 使用Composer将控制台组件引入我们项目

              composer require symfony/console
            • 然后为你的应用程序创建一个入口点,PHP扩展不是必需的,因为我们要使这个文件成为可执行文件,并在文件本身中指定环境。

              touch HelloWorld
              chmod +X HelloWorld
            • 将下面的代码添加到HelloWorld文件中(后面我将为每一行做注解),并在你的终端中执行HelloWorld这个应用程序.

              #!/usr/bin/env php
              <?php require __DIR__.&#39;/vendor/autoload.php&#39;;
              
              use Symfony\Component\Console\Application;
              use Symfony\Component\Console\Input\InputArgument;
              use Symfony\Component\Console\Input\InputInterface;
              use Symfony\Component\Console\Input\InputOption;
              use Symfony\Component\Console\Output\OutputInterface;
              
              (new Application(&#39;Hello World&#39;, &#39;1.0.0&#39;))
                    ->register('greet')
                    ->addArgument('name', InputArgument::OPTIONAL, 'Name of the person')
                    ->addOption('say', null, InputOption::VALUE_REQUIRED, 'Custom greeting')
                    ->setCode(function (InputInterface $input, OutputInterface $output) {
                            
                      $name = $input->getArgument('name');
                      $greeting = $input->getOption('say');
              
                      if (!empty($name) && !empty($greeting)) {
                          return $output->writeln("<info>$greeting $name!</info>");
                      } else if (!empty($name)) {
                          return $output->writeln("<info>Hello $name!</info>");
                      } else if (!empty($greeting)) {
                          return $output->writeln("<info>$greeting World!</info>");
                      } else {
                          return $output->writeln("<info>Hello World!</info>");
                      }
                    })
                    ->getApplication()
                    ->run();

            看,就这样,你拥有了自己的HelloWorld控制台程序
            PHP를 사용하여 명령줄 애플리케이션을 빠르게 구축하는 방법
            当没有指定命令时,HelloWorld默认输出一屏信息提示

            Symfony Console组件给我们提供的应用程序有几个开箱可用的选项的和命令,比如helplist--version

            解释这个神奇的文件内容

            OK,让我们来看看我们的HelloWorld文件中的代码。

            1. 我们引入autoload.php以使用由composer提供的自动加载以及控制台组件提供的各功能。

            InputInterfaceOutputInterface将使应用程序的输入和输出功能变得简单,InputArgumentInputOption将帮助我们处理传递给我们HelloWorld应用程序的选项和参数。

            require __DIR__.'/vendor/autoload.php'; 
            
            use Symfony\Component\Console\Application; 
            use Symfony\Component\Console\Input\InputArgument; 
            use Symfony\Component\Console\Input\InputInterface; 
            use Symfony\Component\Console\Input\InputOption; 
            use Symfony\Component\Console\Output\OutputInterface;
            1. symphony/console通过名称实例化一个新的应用程序HelloWorld (v1.0.0) ,并注册我们的greet

            PHP를 사용하여 명령줄 애플리케이션을 빠르게 구축하는 방법🎜🎜🎜🎜인사say사용 >인사말 맞춤 설정 옵션 🎜
          🎜PHP를 사용하여 명령줄 애플리케이션을 빠르게 구축하는 방법🎜🎜🎜🎜마지막으로 인사 인사 및 인사하는 사람을 맞춤설정하세요🎜
        🎜PHP를 사용하여 명령줄 애플리케이션을 빠르게 구축하는 방법🎜

        저자 소개

        언어와 기술에 국한되지 않고 현재 주로 Laravel 및 VueJs를 사용하여 PHP 및 프런트 엔드 개발에 종사하는 프로그램 개발자입니다. 적합성과 충분성은 끝없는 추구입니다. 🎜개인 홈페이지: https://www.linganmin.cn🎜
        🎜번역자 참고 사항: 이 글의 일부 링크와 이미지 주소는 국내 주소로 대체되었습니다. 번역 오류가 있으면 정정해 주시기 바랍니다.
        즐거운 코딩하세요! 🎜


        🎜

        원본 주소: PHP를 사용하여 명령줄 애플리케이션을 구축하는 방법
        🎜 개발을 하는 경우 엔지니어라면 PHP를 사용하여 많은 애플리케이션을 개발했을 것입니다. 하지만 PHP를 사용하여 명령줄 애플리케이션(도구)을 빠르게 구축하는 방법을 알고 계십니까? 아래에서는 PHP와 유명한 Composer 확장 패키지--Symphony/Console은 명령줄 애플리케이션을 빌드합니다. 🎜🎜Symphony/Console은 <code>Composer로 관리되는 PHP 확장 패키지로, 아름답고 테스트 가능한 PHP 명령줄 생성을 단순화합니다. 애플리케이션 프로세스는 다음을 제공합니다. (선택적/필수) 매개변수 사양 및 옵션 사양(- 기호 사용)과 같은 기본 기능입니다. 이제 함께 애플리케이션 구축을 시작하겠습니다. 🎜🎜평소처럼 "Hello World" 콘솔 애플리케이션을 구축할 예정이지만 (Hello 대신) 사용자 정의 인사말을 지원하고 (World 대신) 마음대로 사람에게 인사할 수 있도록 약간 수정합니다. 🎜

        이 Hello World 애플리케이션에는 다음과 같은 기능이 있습니다.

        🎜🎜🎜 애플리케이션과 상호 작용하는 데 사용할 별도의 greet(인사말) 명령을 제공합니다. 🎜
      2. 🎜🎜greet는 선택적 매개변수(name)를 사용하여 인사받는 사람을 인쇄할 수 있습니다(기본값은 World). 🎜
    • 🎜🎜greet는 옵션(--say)을 사용하여 인사말을 변경할 수 있습니다(기본값은 Hello). 🎜
  5. 🎜🎜매개변수나 옵션을 제공하면 프로그램은 기본적으로 Hello World 메시지를 출력합니다. 🎜

PHP를 사용하여 명령줄 애플리케이션을 구축하는 방법

    🎜🎜프로젝트 및 를 위한 새 디렉터리를 만듭니다. cd를 추가합니다: 🎜
(new Application('Hello World', '1.0.0'))
    ->register('greet')
🎜🎜Composer를 사용하여 콘솔 구성 요소를 프로젝트로 가져옵니다. 🎜
->addArgument('name', InputArgument::OPTIONAL, 'Name of the person') 
->addOption('say', null, InputOption::VALUE_REQUIRED, 'Custom greeting')
🎜🎜그런 다음 애플리케이션의 진입점을 만듭니다. PHP 확장은 필요하지 않습니다. 왜냐하면 우리는 이 파일을 실행 가능하게 만들고 파일 자체에 환경을 지정하기를 원하기 때문입니다. 🎜
->setCode(function (InputInterface $input, OutputInterface $output) {
    $name = $input->getArgument('name');
    $greeting = $input->getOption('say');

    if (!empty($name) && !empty($greeting)) {
        return $output->writeln("<info>$greeting $name!</info>");
    } else if (!empty($name)) {
        return $output->writeln("<info>Hello $name!</info>");
    } else if (!empty($greeting)) {
        return $output->writeln("<info>$greeting World!</info>");
    } else {
        return $output->writeln("<info>Hello World!</info>");
    }
  })
🎜🎜 HelloWorld 파일에 다음 코드를 추가하고(나중에 각 줄에 주석을 달겠습니다) 터미널에서 HelloWorld를 실행하세요. 이 애플리케이션.🎜
->getApplication()
->run();
🎜자, 그게 다입니다. 여러분만의 HelloWorld 콘솔 프로그램이 생겼습니다.
PHP를 사용하여 명령줄 애플리케이션을 빠르게 구축하는 방법
명령이 지정되지 않은 경우 HelloWorld는 기본적으로 한 화면 정보 프롬프트를 출력합니다🎜🎜 Symfony 콘솔 구성 요소는 help, list와 같이 애플리케이션에서 바로 사용할 수 있는 여러 옵션과 명령을 제공합니다. --version🎜

이 마법의 파일 내용을 설명하세요

🎜좋아요, HelloWorld 파일의 코드를 살펴보겠습니다. 🎜🎜🎜🎜composer에서 제공하는 자동 로딩과 콘솔 컴포넌트에서 제공하는 다양한 기능을 사용할 수 있도록 autoload.php를 소개합니다. 🎜🎜InputInterfaceOutputInterface는 애플리케이션의 입력 및 출력 기능을 간단하게 만들어줍니다. InputArgument 및 InputOption은 HelloWorld 애플리케이션에 전달된 옵션과 매개변수를 처리하는 데 도움이 됩니다. 🎜
mkdir hello-world-app && cd hello-world-app
🎜🎜🎜symphony/consoleHelloWorld(v1.0.0)라는 이름으로 새 애플리케이션을 인스턴스화하고 greet 주문을 등록합니다. 🎜
(new Application('Hello World', '1.0.0'))
    ->register('greet')
  • 我们添加一个可选的name参数(addArgument()),并提供参数的简短描述。然后,我们使用这个addOption()方法添加一个say选项。请注意,选项始终是可选的,但您可以指定要传递的值,也可以仅仅将其用作指boolean标识。

    ->addArgument('name', InputArgument::OPTIONAL, 'Name of the person') 
    ->addOption('say', null, InputOption::VALUE_REQUIRED, 'Custom greeting')
  • setCode()方法中的代码会包含我们应用程序的主逻辑,它会根据传递的参数和选项打印一个问候语到终端。我们监听$input对象,使用getArgument()getOption()辅助方法获取传递给greet的选项和参数,然后,我们只需要检查传递了哪些参数或者选项,并相应的(使用$output对象)向控制台输出打印问候语。这个writeln()方法可以根据标签格式化文本,比如输出不同颜色的info,errorwarning

    ->setCode(function (InputInterface $input, OutputInterface $output) {
        $name = $input->getArgument('name');
        $greeting = $input->getOption('say');
    
        if (!empty($name) && !empty($greeting)) {
            return $output->writeln("<info>$greeting $name!</info>");
        } else if (!empty($name)) {
            return $output->writeln("<info>Hello $name!</info>");
        } else if (!empty($greeting)) {
            return $output->writeln("<info>$greeting World!</info>");
        } else {
            return $output->writeln("<info>Hello World!</info>");
        }
      })
  • 最后我们引导应用程序并调用他的方法,以便他做好随时接收和处理greet命令。

    ->getApplication()
    ->run();
  • 现在让我们在实例中看看我们HelloWorld程序

    1. greet不传递任何参数和选项

    PHP를 사용하여 명령줄 애플리케이션을 빠르게 구축하는 방법

    1. greet有一个可选的name参数

    PHP를 사용하여 명령줄 애플리케이션을 빠르게 구축하는 방법

    1. greet使用say选项自定义问候语

    PHP를 사용하여 명령줄 애플리케이션을 빠르게 구축하는 방법

    1. 最后,greet自定义问候语和问候人

    PHP를 사용하여 명령줄 애플리케이션을 빠르게 구축하는 방법

    相关推荐:

    PHP命令行

    关于webpack命令行的详细介绍

    关于获取命令行参数的7篇文章推荐


    위 내용은 PHP를 사용하여 명령줄 애플리케이션을 빠르게 구축하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

    성명
    본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
    과대 광고 : 오늘 PHP의 역할을 평가합니다과대 광고 : 오늘 PHP의 역할을 평가합니다Apr 12, 2025 am 12:17 AM

    PHP는 현대적인 프로그래밍, 특히 웹 개발 분야에서 강력하고 널리 사용되는 도구로 남아 있습니다. 1) PHP는 사용하기 쉽고 데이터베이스와 완벽하게 통합되며 많은 개발자에게 가장 먼저 선택됩니다. 2) 동적 컨텐츠 생성 및 객체 지향 프로그래밍을 지원하여 웹 사이트를 신속하게 작성하고 유지 관리하는 데 적합합니다. 3) 데이터베이스 쿼리를 캐싱하고 최적화함으로써 PHP의 성능을 향상시킬 수 있으며, 광범위한 커뮤니티와 풍부한 생태계는 오늘날의 기술 스택에 여전히 중요합니다.

    PHP의 약한 참고 자료는 무엇이며 언제 유용합니까?PHP의 약한 참고 자료는 무엇이며 언제 유용합니까?Apr 12, 2025 am 12:13 AM

    PHP에서는 약한 참조가 약한 회의 클래스를 통해 구현되며 쓰레기 수집가가 물체를 되 찾는 것을 방해하지 않습니다. 약한 참조는 캐싱 시스템 및 이벤트 리스너와 같은 시나리오에 적합합니다. 물체의 생존을 보장 할 수 없으며 쓰레기 수집이 지연 될 수 있음에 주목해야합니다.

    PHP의 __invoke 마법 방법을 설명하십시오.PHP의 __invoke 마법 방법을 설명하십시오.Apr 12, 2025 am 12:07 AM

    \ _ \ _ 호출 메소드를 사용하면 객체를 함수처럼 호출 할 수 있습니다. 1. 객체를 호출 할 수 있도록 메소드를 호출하는 \ _ \ _ 정의하십시오. 2. $ obj (...) 구문을 사용할 때 PHP는 \ _ \ _ invoke 메소드를 실행합니다. 3. 로깅 및 계산기, 코드 유연성 및 가독성 향상과 같은 시나리오에 적합합니다.

    동시성에 대해 PHP 8.1의 섬유를 설명하십시오.동시성에 대해 PHP 8.1의 섬유를 설명하십시오.Apr 12, 2025 am 12:05 AM

    섬유는 PHP8.1에 도입되어 동시 처리 기능을 향상시켰다. 1) 섬유는 코 루틴과 유사한 가벼운 동시성 모델입니다. 2) 개발자는 작업의 실행 흐름을 수동으로 제어 할 수 있으며 I/O 집약적 작업을 처리하는 데 적합합니다. 3) 섬유를 사용하면보다 효율적이고 반응이 좋은 코드를 작성할 수 있습니다.

    PHP 커뮤니티 : 자원, 지원 및 개발PHP 커뮤니티 : 자원, 지원 및 개발Apr 12, 2025 am 12:04 AM

    PHP 커뮤니티는 개발자 성장을 돕기 위해 풍부한 자원과 지원을 제공합니다. 1) 자료에는 공식 문서, 튜토리얼, 블로그 및 Laravel 및 Symfony와 같은 오픈 소스 프로젝트가 포함됩니다. 2) 지원은 StackoverFlow, Reddit 및 Slack 채널을 통해 얻을 수 있습니다. 3) RFC에 따라 개발 동향을 배울 수 있습니다. 4) 적극적인 참여, 코드에 대한 기여 및 학습 공유를 통해 커뮤니티에 통합 될 수 있습니다.

    PHP vs. Python : 차이점 이해PHP vs. Python : 차이점 이해Apr 11, 2025 am 12:15 AM

    PHP와 Python은 각각 고유 한 장점이 있으며 선택은 프로젝트 요구 사항을 기반으로해야합니다. 1.PHP는 간단한 구문과 높은 실행 효율로 웹 개발에 적합합니다. 2. Python은 간결한 구문 및 풍부한 라이브러리를 갖춘 데이터 과학 및 기계 학습에 적합합니다.

    PHP : 죽어 가거나 단순히 적응하고 있습니까?PHP : 죽어 가거나 단순히 적응하고 있습니까?Apr 11, 2025 am 12:13 AM

    PHP는 죽지 않고 끊임없이 적응하고 진화합니다. 1) PHP는 1994 년부터 새로운 기술 트렌드에 적응하기 위해 여러 버전 반복을 겪었습니다. 2) 현재 전자 상거래, 컨텐츠 관리 시스템 및 기타 분야에서 널리 사용됩니다. 3) PHP8은 성능과 현대화를 개선하기 위해 JIT 컴파일러 및 기타 기능을 소개합니다. 4) Opcache를 사용하고 PSR-12 표준을 따라 성능 및 코드 품질을 최적화하십시오.

    PHP의 미래 : 적응 및 혁신PHP의 미래 : 적응 및 혁신Apr 11, 2025 am 12:01 AM

    PHP의 미래는 새로운 기술 트렌드에 적응하고 혁신적인 기능을 도입함으로써 달성 될 것입니다. 1) 클라우드 컴퓨팅, 컨테이너화 및 마이크로 서비스 아키텍처에 적응, Docker 및 Kubernetes 지원; 2) 성능 및 데이터 처리 효율을 향상시키기 위해 JIT 컴파일러 및 열거 유형을 도입합니다. 3) 지속적으로 성능을 최적화하고 모범 사례를 홍보합니다.

    See all articles

    핫 AI 도구

    Undresser.AI Undress

    Undresser.AI Undress

    사실적인 누드 사진을 만들기 위한 AI 기반 앱

    AI Clothes Remover

    AI Clothes Remover

    사진에서 옷을 제거하는 온라인 AI 도구입니다.

    Undress AI Tool

    Undress AI Tool

    무료로 이미지를 벗다

    Clothoff.io

    Clothoff.io

    AI 옷 제거제

    AI Hentai Generator

    AI Hentai Generator

    AI Hentai를 무료로 생성하십시오.

    인기 기사

    R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
    3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
    R.E.P.O. 최고의 그래픽 설정
    3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
    R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
    3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
    WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
    3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌

    뜨거운 도구

    Dreamweaver Mac版

    Dreamweaver Mac版

    시각적 웹 개발 도구

    맨티스BT

    맨티스BT

    Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

    Eclipse용 SAP NetWeaver 서버 어댑터

    Eclipse용 SAP NetWeaver 서버 어댑터

    Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

    VSCode Windows 64비트 다운로드

    VSCode Windows 64비트 다운로드

    Microsoft에서 출시한 강력한 무료 IDE 편집기

    PhpStorm 맥 버전

    PhpStorm 맥 버전

    최신(2018.2.1) 전문 PHP 통합 개발 도구