目次
要約
はじめに
単純な http サーバー
cli は 4 つのタグをサポートします
clier は、
ホームページ ウェブフロントエンド htmlチュートリアル go_html/css_WEB-ITnose を使用してコマンド ライン プログラムを構築する簡単な方法

go_html/css_WEB-ITnose を使用してコマンド ライン プログラムを構築する簡単な方法

Jun 24, 2016 am 11:18 AM

要約

この記事では、コマンド ライン プログラムを構築するためのオープン ソース ツール mkideal/cli を紹介します。 golang 標準ライブラリ flag は、コマンドラインパラメータ解析用に公式に組み込まれた実用的なライブラリです。この記事で紹介する cli の主な機能は基本的に flag ライブラリと同じですが、比較的シンプルでわかりやすい使い方と、より実用的なツールを提供します。 。 cli の主な機能には以下が含まれます:

  • Golang ベースのタグとリフレクションの実装。
  • パラメータのタイプと範囲のチェック、およびカスタム検証関数。
  • -h や --help などの短い形式と長い形式のフラグをサポートします。
  • 環境変数をデフォルト値として使用する場合でも、デフォルト値の指定をサポートします。
  • パラメータとして配列とマップをサポートします。
  • フレンドリーなヘルプ表示。
  • ……

cli は github 上のオープンソースですhttps://github.com/mkideal/cli

はじめに

コマンドラインプログラムには豪華なインターフェイスはありませんが、サーバー側では、コマンドライン プログラムは利用できません。 不可欠ですが、多くの場合、グラフィカル インターフェイスよりも使いやすいです。コマンド ライン プログラムは Unix/Linux オペレーティング システムで非常に一般的であり、多数のプログラムがシステムにプリインストールされています。 cli ツールは、このようなコマンド ライン プログラムを簡単に構築するために使用される go 言語ライブラリです。 まず簡単な例を見てみましょう:

package mainimport (	"github.com/mkideal/cli")type argT struct {	cli.Helper}func main() {	cli.Run(&argT{}, func(ctx *cli.Context) error {		argv := ctx.Argv().(*argT)		if argv.Help {			ctx.WriteUsage()		} else {			ctx.String("hello\n")		}		return nil	})}
ログイン後にコピー

このコードをコンパイルして実行します

$ go build -o app$ ./apphello$ ./app -hOptions:  -h, --help     display help
ログイン後にコピー

もちろん、このコードには実際の関数はありません。コードの 12 行目は、cli の Run 関数を呼び出します。関数のプロトタイプは次のとおりです:

func Run(argv interface{}, fn func(*Context) error, descs ...string)
ログイン後にコピー

パラメータ argv には、実行中にコマンド ライン パラメータを解析することによって値が割り当てられ、最後に Context オブジェクトに挿入されます。コールバック関数 fn に渡されます。コールバック関数の ctx.Argv() を通じて argv を取得します。

このサンプルコードの argT は cli.Helper から継承されており、その定義は次のとおりです:

type Helper struct { Help bool `cli:"!h,help" usage:"display help"`}
ログイン後にコピー

さて、より詳細に説明するために、より実用的なプログラムを作成しましょう。

単純な http サーバー

package mainimport (	"fmt"	"net/http"	"github.com/mkideal/cli")type argT struct {	cli.Helper	Host string `cli:"H,host" usage:"specify host" dft:"0.0.0.0"`	Port uint16 `cli:"p,port" usage:"specify port" dft:"8080"`	Dir  string `cli:"d,dir" usage:"static files directory" dft:"./"`}func main() {	cli.SetUsageStyle(cli.ManualStyle)	cli.Run(new(argT), func(ctx *cli.Context) error {		argv := ctx.Argv().(*argT)		if argv.Help {			ctx.WriteUsage()			return nil		}		http.Handle("/", http.FileServer(http.Dir(argv.Dir)))		addr := fmt.Sprintf("%s:%d", argv.Host, argv.Port)		ctx.String("listening on %s\n", addr)		http.ListenAndServe(addr, nil)		return nil	})}
ログイン後にコピー

この例では、パラメーター オブジェクト argT にさらにいくつかの便利なフィールドがあります: Host Port Dir

まずコンパイルして実行しましょう

$ go build -o httpd$ ./httpd -h
ログイン後にコピー

さて、を作成するhtml ディレクトリに移動し、その内容を含む新しいファイルindex.html を作成します

<h1>Hello, this is my http server!</h1>
ログイン後にコピー

次に、http サーバーを起動します

$ mkdir html$ echo "<h1>Hello, this is my http server!</h1>" > html/index.html$ ./httpd -d htmllistening on 0.0.0.0:8080
ログイン後にコピー

次に、ブラウザから 127.0.0.1:8080 にアクセスすると、

が表示されます。デフォルトのポート 8080 の代わりに他のポートを指定できます。たとえば、指定されたポートが 3000 の場合、

$ ./httpd -d html --port=3000
ログイン後にコピー

または

$ ./httpd -d html --port 3000
ログイン後にコピー

または

$ ./httpd -d html -p=3000
ログイン後にコピー

または

りー

次にそれについて話しましょう パラメータ定義に表示され、パラメータを解析してヘルパーを表示するための鍵となるラベルです。

タグ cli、使用法、dft

cli は 4 つのタグをサポートします

cli - パラメーター フラグ名 (例では cli:"h,help" cli:"H,host" など)
  • uses - パラメーターの使用法の説明 、ヘルプに表示されるテキストです
  • dft - パラメータのデフォルト値を指定します。次の dft: "$HOME" のように環境変数をデフォルト値として指定できます
  • name - パラメータの参照名、実際の機能はありません
  • 作成 コマンド ライン プログラム用のコマンド ライン ツール clier goplus

clier は、

mkideal/cli

にあるコマンド ライン プログラムで、これも cli を使用して構築されます。 clier は、次のようなコマンドを作成するために使用されます。

$ ./httpd -d html -p 3000
ログイン後にコピー

goplus

新しいサブコマンドは、完全な cli ベースのコマンド ライン プログラムを構築できます。使用例

$ clier hello$ clier -s "this is hello command's description" hello
ログイン後にコピー

この記事は cli の簡単な紹介です。 cli については以下の記事で詳しく紹介しています

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホット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衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

HTMLは初心者のために簡単に学ぶことができますか? HTMLは初心者のために簡単に学ぶことができますか? Apr 07, 2025 am 12:11 AM

HTMLは、簡単に学習しやすく、結果をすばやく見ることができるため、初心者に適しています。 1)HTMLの学習曲線はスムーズで簡単に開始できます。 2)基本タグをマスターして、Webページの作成を開始します。 3)柔軟性が高く、CSSおよびJavaScriptと組み合わせて使用​​できます。 4)豊富な学習リソースと最新のツールは、学習プロセスをサポートしています。

HTML、CSS、およびJavaScriptの役割:コアの責任 HTML、CSS、およびJavaScriptの役割:コアの責任 Apr 08, 2025 pm 07:05 PM

HTMLはWeb構造を定義し、CSSはスタイルとレイアウトを担当し、JavaScriptは動的な相互作用を提供します。 3人はWeb開発で職務を遂行し、共同でカラフルなWebサイトを構築します。

HTMLでの開始タグの例は何ですか? HTMLでの開始タグの例は何ですか? Apr 06, 2025 am 12:04 AM

Anexampleapalofastartingtaginhtmlis、それはaperginsaparagraph.startingtagsaresentionentientiontheyinitiateelements、definetheirtypes、およびarecrucialforurturingwebpagesandcontingthomedomを構築します。

HTML、CSS、およびJavaScriptの理解:初心者向けガイド HTML、CSS、およびJavaScriptの理解:初心者向けガイド Apr 12, 2025 am 12:02 AM

webdevelopmentReliesOnhtml、css、andjavascript:1)htmlStructuresContent、2)cssStylesit、および3)Javascriptaddsinteractivity、形成、

Giteeページ静的なWebサイトの展開に失敗しました:単一のファイル404エラーをトラブルシューティングと解決する方法 Giteeページ静的なWebサイトの展開に失敗しました:単一のファイル404エラーをトラブルシューティングと解決する方法 Apr 04, 2025 pm 11:54 PM

GiteEpages静的Webサイトの展開が失敗しました:404エラーのトラブルシューティングと解像度Giteeを使用する

WebアノテーションにY軸位置の適応レイアウトを実装する方法は? WebアノテーションにY軸位置の適応レイアウトを実装する方法は? Apr 04, 2025 pm 11:30 PM

Y軸位置Webアノテーション機能の適応アルゴリズムこの記事では、単語文書と同様の注釈関数、特に注釈間の間隔を扱う方法を実装する方法を探ります...

CSS3とJavaScriptを使用して、クリック後に周囲の写真を散乱および拡大する効果を実現する方法は? CSS3とJavaScriptを使用して、クリック後に周囲の写真を散乱および拡大する効果を実現する方法は? Apr 05, 2025 am 06:15 AM

画像をクリックした後、散乱と周囲の画像を拡大する効果を実現するには、多くのWebデザインがインタラクティブな効果を実現する必要があります。特定の画像をクリックして周囲を作成してください...

Routerフォルダーの下のindex.jsファイルでvue.use(vuerouter)を呼び出す必要があるのはなぜですか? Routerフォルダーの下のindex.jsファイルでvue.use(vuerouter)を呼び出す必要があるのはなぜですか? Apr 05, 2025 pm 01:03 PM

Vueアプリケーションを開発するときに、ルーターフォルダーの下にindex.jsファイルにvuerouterを登録する必要性があるため、ルーティング構成で問題が発生することがよくあります。特別...

See all articles