あなたが Web
開発エンジニアであれば、PHP
を使用して多くの Web
アプリケーションを開発したことがあるはずです。しかし、PHP
を使用してコマンド ライン アプリケーション (ツール) を迅速に構築する方法をご存知ですか? 以下では、PHP
と有名な Composer 拡張パッケージ -- Symphony/Console はコマンド ライン アプリケーションを構築します。 <code>Web
开发工程师,那么你一定使用PHP
开发过很多Web
应用程序。但是你知道如何使用PHP
快速构建一个命令行应用程序(工具)吗?下面我将向您展示如何使用PHP
和一个著名的的Composer
扩展包--Symphony/Console构建一个命令行应用。
Symphony/Console是一个使用Composer
管理的PHP
扩展包,它简化了创建一个漂亮的、可测试的PHP
命令行应用的过程,它提供了开箱即用的诸如(可选/必选的)参数规范和选项规范(使用-
符号)等功能。那么,我们来一起开始构建我们的应用。
按照惯例,我们将构建一个“Hello World”的控制台应用程序,但是要稍微修改一下它,让它支持自定义问候语(代替Hello),并且可以随意的去问候一个人(代替world)。
为我们提供一个单独的greet
(问候)命令,我们将使用它来与应用程序交互。
greet
可以接受一个可选的参数(name
)来打印出一个被问候的人(默认是World)。
greet
可以接受一个选项(--say
)来更改问候语(默认是Hello)。
如果我们么样给定参数或者选项,程序将默认输出一个Hello World
消息。
为我们的项目创建新的目录并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__.'/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; (new Application('Hello World', '1.0.0')) ->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
控制台程序
当没有指定命令时,HelloWorld默认输出一屏信息提示
Symfony Console
组件给我们提供的应用程序有几个开箱可用的选项的和命令,比如help
,list
和--version
OK,让我们来看看我们的HelloWorld
文件中的代码。
我们引入autoload.php
以使用由composer
提供的自动加载以及控制台组件提供的各功能。
InputInterface
和OutputInterface
将使应用程序的输入和输出功能变得简单,InputArgument
和InputOption
将帮助我们处理传递给我们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;
symphony/console
通过名称实例化一个新的应用程序HelloWorld (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
,error
和warning
。
->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();
greet
Composer
で管理される PHP
拡張パッケージです。これにより、美しくテスト可能な PHP
コマンド ラインの作成が簡素化されます。アプリケーション プロセスは、 (オプション/必須) パラメータ指定やオプション指定 (-
記号を使用) などの -of-the-box 関数。それでは、一緒にアプリケーションの構築を始めましょう。 greet
(greeting) を提供してください。コマンド。アプリケーションと対話するために使用します。 greet
は、挨拶される人を出力するためのオプションのパラメータ (name
) を受け入れることができます (デフォルトは World)。 🎜🎜greet
は、挨拶を変更するオプション (--say
) を受け入れることができます (デフォルトは Hello)。 🎜🎜Hello World
メッセージを出力します。 🎜🎜🎜cd
それに進みます: 🎜mkdir hello-world-app && cd hello-world-app
composer require symfony/console
touch HelloWorld chmod +X HelloWorld
HelloWorld
ファイルに追加し (後で各行に注釈を付けます)、ターミナル Application.🎜#!/usr/bin/env php <?php 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; (new Application('Hello World', '1.0.0')) ->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
コンソール プログラムができました🎜🎜🎜🎜 コマンドが指定されていない場合、HelloWorld はデフォルトで情報画面を出力します🎜🎜Symfony Console
コンポーネントはアプリケーションを提供します。利用可能なオプションとコマンドがいくつかあります。 help
、list
、--version
などのボックス🎜HelloWorld
ファイル内のコードを見てください。 🎜composer
とコンソール コンポーネントの Each 関数によって提供される自動読み込みを使用する autoload.php
を紹介します。 🎜🎜🎜🎜InputInterface
と OutputInterface
はアプリケーションの入出力関数をシンプルにし、InputArgument
と InputOption
は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;
symphony/console
HelloWorld (v1.0.0)
という名前で新しいアプリケーションをインスタンス化し、登録しますgreet
コマンドです。 🎜(new Application('Hello World', '1.0.0')) ->register('greet')
name
パラメーター (addArgument()
) を追加し、パラメーターの簡単な説明を提供します。次に、この addOption()
メソッドを使用して say
オプションを追加します。オプションは常にオプションですが、渡す値を指定することも、単にブール識別子への参照として使用することもできることに注意してください。 🎜->addArgument('name', InputArgument::OPTIONAL, 'Name of the person') ->addOption('say', null, InputOption::VALUE_REQUIRED, 'Custom greeting')
setCode()
メソッドのコードには、渡されたパラメーターとオプションに基づいて端末に挨拶を出力するアプリケーションのメイン ロジックが含まれます。 $input
オブジェクトをリッスンし、getArgument()
および getOption()
ヘルパー メソッドを使用して、greet に渡されるオプションを取得します。
とパラメータを指定したら、渡されたパラメータまたはオプションを確認し、それに応じて挨拶をコンソールに出力するだけです ($output
オブジェクトを使用)。この writeln()
メソッドは、info
、error
、warning
の異なる色の出力など、タグに従ってテキストをフォーマットできます。 > 。 🎜->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();
greet
が通過しませんパラメータとオプション 🎜🎜🎜🎜🎜🎜🎜🎜greet
にはオプションの name
パラメータがありますgreet
有一个可选的name
参数
greet
使用say
选项自定义问候语
最后,greet
自定义问候语和问候人
程序开发人员,不拘泥于语言与技术,目前主要从事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)。
为我们提供一个单独的greet
(问候)命令,我们将使用它来与应用程序交互。
greet
可以接受一个可选的参数(name
)来打印出一个被问候的人(默认是World)。
greet
可以接受一个选项(--say
)来更改问候语(默认是Hello)。
如果我们么样给定参数或者选项,程序将默认输出一个Hello World
消息。
为我们的项目创建新的目录并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__.'/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; (new Application('Hello World', '1.0.0')) ->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
控制台程序
当没有指定命令时,HelloWorld默认输出一屏信息提示
Symfony Console
组件给我们提供的应用程序有几个开箱可用的选项的和命令,比如help
,list
和--version
OK,让我们来看看我们的HelloWorld
文件中的代码。
我们引入autoload.php
以使用由composer
提供的自动加载以及控制台组件提供的各功能。
InputInterface
和OutputInterface
将使应用程序的输入和输出功能变得简单,InputArgument
和InputOption
将帮助我们处理传递给我们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;
symphony/console
通过名称实例化一个新的应用程序HelloWorld (v1.0.0)
,并注册我们的greet
greet
say
を使用します>挨拶をカスタマイズするオプション 🎜greet
で挨拶と挨拶担当者をカスタマイズします🎜言語やテクノロジーに限定されないプログラム開発者。現在は主に Laravel や VueJs を使用した PHP やフロントエンド開発に従事しています。適合性と十分性は終わりのない追求です。 🎜個人ウェブサイト: https://www.linganmin.cn🎜🎜翻訳者注: この記事の一部のリンクと画像アドレスは国内のアドレスに置き換えられています。翻訳エラーがある場合は修正してください。
🎜
元のアドレス: PHP を使用してコマンド ライン アプリケーションを構築するには?🎜
Web
開発の場合エンジニアであれば、PHP
を使用して多くの Web
アプリケーションを開発したことがあるはずです。しかし、PHP
を使用してコマンド ライン アプリケーション (ツール) を迅速に構築する方法をご存知ですか? 以下では、PHP
と有名な Composer 拡張パッケージ -- Symphony/Console はコマンド ライン アプリケーションを構築します。 🎜🎜Symphony/Console は、<code>Composer
で管理される PHP
拡張パッケージです。これにより、美しくテスト可能な PHP
コマンド ラインの作成が簡素化されます。アプリケーション プロセスは、 (オプション/必須) パラメータ指定やオプション指定 (-
記号を使用) などの -of-the-box 関数。それでは、一緒にアプリケーションの構築を始めましょう。 🎜🎜 いつものように、「Hello World」コンソール アプリケーションを構築しますが、(Hello の代わりに) カスタムの挨拶をサポートし、(World の代わりに) 自由に人に挨拶できるように少し変更します。 🎜greet
(挨拶) コマンドを提供します。 🎜
greet
は、挨拶される人を出力するためのオプションのパラメータ (name
) を受け入れることができます (デフォルトは World)。 🎜greet
は、挨拶を変更するオプション (--say
) を受け入れることができます (デフォルトは Hello)。 🎜Hello World
メッセージを出力します。 🎜 cd
をそれに追加します: 🎜(new Application('Hello World', '1.0.0')) ->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>"); } })
HelloWorld
ファイルに追加し (後で各行に注釈を付けます)、ターミナルのこのアプリケーションで HelloWorld
を実行します。🎜->getApplication() ->run();
HelloWorld
コンソール プログラムが完成しました。Symfony Console
コンポーネントは、help
、list code>、<code> など、アプリケーションですぐに使用できるいくつかのオプションとコマンドを提供します。 --version
🎜HelloWorld
ファイルのコードを見てみましょう。 🎜🎜🎜🎜composer
によって提供される自動読み込みと、コンソール コンポーネントによって提供されるさまざまな機能を使用するための autoload.php
を紹介します。 🎜🎜InputInterface
と OutputInterface
は、アプリケーションの入出力関数をシンプルにします。InputArgument
と InputOption は、HelloWorld アプリケーションに渡されるオプションとパラメータを処理するのに役立ちます。 🎜mkdir hello-world-app && cd hello-world-app
symphony/console
HelloWorld (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
,error
和warning
。
->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();
greet
不传递任何参数和选项
greet
有一个可选的name
参数
greet
使用say
选项自定义问候语
最后,greet
自定义问候语和问候人
相关推荐:
以上がPHP を使用してコマンドライン アプリケーションをすばやく構築する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。