コマンドラインフラグ
は、コマンドラインプログラムに対してオプションを指定する
一般的な方法です。例えば、 |
|
package main |
|
Go は、基本的なコマンドラインフラグのパースをサポートする
|
import ( "flag" "fmt" ) |
func main() { |
|
基本的なフラグ宣言は、文字列、整数、真偽値に対して
利用できます。ここでは、文字列フラグ |
wordPtr := flag.String("word", "foo", "a string") |
次の例は、 |
numbPtr := flag.Int("numb", 42, "an int") forkPtr := flag.Bool("fork", false, "a bool") |
プログラムの別の場所で宣言された変数を使うような オプションを宣言することも可能です。 フラグを宣言する関数にポインタの形で渡す必要がある点に 注意してください。 |
var svar string flag.StringVar(&svar, "svar", "bar", "a string var") |
すべてのフラグを宣言したら、コマンドラインをパースするために
|
flag.Parse() |
ここでは、パースしたオプションと残りの任意の引数を
単に出力します。実際のオプション値を取得するために、
|
fmt.Println("word:", *wordPtr) fmt.Println("numb:", *numbPtr) fmt.Println("fork:", *forkPtr) fmt.Println("svar:", svar) fmt.Println("tail:", flag.Args()) } |
コマンドラインフラグをもつプログラムを試すためには、 先にコンパイルして、出力されたバイナリを直接実行するのがよいです。 |
$ go build command-line-flags.go
|
まずはビルドされたプログラムにすべてのフラグの値を指定して みましょう。 |
$ ./command-line-flags -word=opt -numb=7 -fork -svar=flag word: opt numb: 7 fork: true svar: flag tail: [] |
フラグを省略すると、 自動的にフラグごとのデフォルト値となる点に注意してください。 |
$ ./command-line-flags -word=opt word: opt numb: 42 fork: false svar: bar tail: [] |
位置引数は、任意のフラグの後に続けて指定できます。 |
$ ./command-line-flags -word=opt a1 a2 a3 word: opt ... tail: [a1 a2 a3] |
|
$ ./command-line-flags -word=opt a1 a2 a3 -numb=7 word: opt numb: 42 fork: false svar: bar tail: [a1 a2 a3 -numb=7] |
コマンドラインプログラムに対して自動生成された
ヘルプテキストを取得するには、 |
$ ./command-line-flags -h Usage of ./command-line-flags: -fork=false: a bool -numb=42: an int -svar="bar": a string var -word="foo": a string |
|
$ ./command-line-flags -wat flag provided but not defined: -wat Usage of ./command-line-flags: ... |
Next example: Command-Line Subcommands.