Goでコマンドライン引数にアクセスするにはどうすればよいですか?それらは引数としてに渡されませんmain
。
おそらく複数のパッケージをリンクすることによって作成された完全なプログラムには、関数を備えたmainという1つのパッケージが必要です
func main() { ... }
定義されています。関数main.main()は引数をとらず、値を返しません。
Goでコマンドライン引数にアクセスするにはどうすればよいですか?それらは引数としてに渡されませんmain
。
おそらく複数のパッケージをリンクすることによって作成された完全なプログラムには、関数を備えたmainという1つのパッケージが必要です
func main() { ... }
定義されています。関数main.main()は引数をとらず、値を返しません。
os.Exit()
て特定の終了コードを呼び出しプロセスに返すことができることに注意してください。
回答:
os.Args
変数を使用してコマンドライン引数にアクセスできます。例えば、
package main
import (
"fmt"
"os"
)
func main() {
fmt.Println(len(os.Args), os.Args)
}
コマンドラインフラグ解析を実装するflagパッケージを使用することもできます。
コマンドライン引数はos.Argsにあります。ほとんどの場合、パッケージフラグの方が優れていますが、引数の解析を行うためです。
Flagはそのための良いパッケージです。
// [_Command-line flags_](http://en.wikipedia.org/wiki/Command-line_interface#Command-line_option)
// are a common way to specify options for command-line
// programs. For example, in `wc -l` the `-l` is a
// command-line flag.
package main
// Go provides a `flag` package supporting basic
// command-line flag parsing. We'll use this package to
// implement our example command-line program.
import "flag"
import "fmt"
func main() {
// Basic flag declarations are available for string,
// integer, and boolean options. Here we declare a
// string flag `word` with a default value `"foo"`
// and a short description. This `flag.String` function
// returns a string pointer (not a string value);
// we'll see how to use this pointer below.
wordPtr := flag.String("word", "foo", "a string")
// This declares `numb` and `fork` flags, using a
// similar approach to the `word` flag.
numbPtr := flag.Int("numb", 42, "an int")
boolPtr := flag.Bool("fork", false, "a bool")
// It's also possible to declare an option that uses an
// existing var declared elsewhere in the program.
// Note that we need to pass in a pointer to the flag
// declaration function.
var svar string
flag.StringVar(&svar, "svar", "bar", "a string var")
// Once all flags are declared, call `flag.Parse()`
// to execute the command-line parsing.
flag.Parse()
// Here we'll just dump out the parsed options and
// any trailing positional arguments. Note that we
// need to dereference the pointers with e.g. `*wordPtr`
// to get the actual option values.
fmt.Println("word:", *wordPtr)
fmt.Println("numb:", *numbPtr)
fmt.Println("fork:", *boolPtr)
fmt.Println("svar:", svar)
fmt.Println("tail:", flag.Args())
}
素早い回答:
package main
import ("fmt"
"os"
)
func main() {
argsWithProg := os.Args
argsWithoutProg := os.Args[1:]
arg := os.Args[3]
fmt.Println(argsWithProg)
fmt.Println(argsWithoutProg)
fmt.Println(arg)
}
テスト: $ go run test.go 1 2 3 4 5
アウト:
[/tmp/go-build162373819/command-line-arguments/_obj/exe/modbus 1 2 3 4 5]
[1 2 3 4 5]
3
注:
os.Args
生のコマンドライン引数へのアクセスを提供します。このスライスの最初の値はプログラムへのパスであり、プログラムos.Args[1:]
への引数を保持していることに注意してください。 参照
たとえば、Golangフラグパッケージを使用できます。
package main
import (
"flag"
"fmt"
)
func main() {
wordPtr := flag.String("word", "default value", "a string for description")
flag.Parse()
fmt.Println("word:", *wordPtr)
}
CLIで呼び出す
go run main.go -word=hello
出力
word: hello
flag
組み込みのGolangモジュールを見てみます。解析がos.Args
少し簡単になります