1.27 Go命令行参数标记

命令行参数标记是为命令行程序指定选项参数的常用方法。例如,在命令wc -l中,-l就是一个命令行参数标记。

Go提供了flag包来支持基本的命令行标记解析。我们这里将要使用这个包提供的方法来实现带选项的命令行程序。

package mainimport "flag"import "fmt"func main() {    // 基础的标记声明适用于string,integer和bool型选项。    // 这里我们定义了一个标记`word`,默认值为`foo`和一    // 个简短的描述。`flag.String`函数返回一个字符串指    // 针(而不是一个字符串值),我们下面将演示如何使    // 用这个指针    wordPtr := flag.String("word", "foo", "a string")    // 这里定义了两个标记,一个`numb`,另一个是`fork`,    // 使用和上面定义`word`标记相似的方法    numbPtr := flag.Int("numb", 42, "an int")    boolPtr := flag.Bool("fork", false, "a bool")    // 你也可以程序中任意地方定义的变量来定义选项,只    // 需要把该变量的地址传递给flag声明函数即可    var svar string    flag.StringVar(&svar, "svar", "bar", "a string var")    // 当所有的flag声明完成后,使用`flag.Parse()`来分    // 解命令行选项    flag.Parse()    // 这里我们仅仅输出解析后的选项和任何紧跟着的位置    // 参数,注意我们需要使用`*wordPtr`的方式来获取最    // 后的选项值    fmt.Println("word:", *wordPtr)    fmt.Println("numb:", *numbPtr)    fmt.Println("fork:", *boolPtr)    fmt.Println("svar:", svar)    fmt.Println("tail:", flag.Args())}

为了运行示例,你需要先将程序编译为可执行文件。

go build command-line-flags.go

下面分别看看给予该命令行程序不同选项参数的例子:

(1) 给所有的选项设置一个参数

$ ./command-line-flags -word=opt -numb=7 -fork -svar=flagword: optnumb: 7fork: truesvar: flagtail: []

(2) 如果你不设置flag,那么它们自动采用默认的值

$ ./command-line-flags -word=optword: optnumb: 42fork: falsesvar: bartail: []

(3) 尾部的位置参数可以出现在任意一个flag后面

$ ./command-line-flags -word=opt a1 a2 a3word: optnumb: 42fork: falsesvar: bartail: [a1 a2 a3]

(4) 注意flag包要求所有的flag都必须出现在尾部位置参数的前面,否则这些flag将被当作位置参数处理

$ ./command-line-flags -word=opt a1 a2 a3 -numb=7word: optnumb: 42fork: falsesvar: bartrailing: [a1 a2 a3 -numb=7]

(5) 使用-h或者--help这两个flag来自动地生成命令行程序的帮助信息

$ ./command-line-flags -hUsage of ./command-line-flags:  -fork=false: a bool  -numb=42: an int  -svar="bar": a string var  -word="foo": a string

(6) 如果你提供了一个程序不支持的flag,那么程序会打印一个错误信息和帮助信息

$ ./command-line-flags -watflag provided but not defined: -watUsage of ./go_cmd_flag:  -fork=false: a bool  -numb=42: an int  -svar="bar": a string var  -word="foo": a string

Leave a Reply

Your email address will not be published. Required fields are marked *