Go Flag

  • Go 提供了一个 flag 包,支持基本的命令行标志解析。我们将用这个包来实现我们的命令行程序示例。

    1、设置提示接收参数

    1
    2
    3
    4
    5
    6
    7
    8
    9
    //基本的标记声明仅支持字符串、整数和布尔值选项。这里我们声明一个默认值为 "foo" 的字符串标志 word并带有一个简短的描述。这里的 flag.String 函数返回一个字符串指针(不是一个字符串值),在下面我们会看到是如何使用这个指针的。
    wordPtr := flag.String("word", "foo", "a string")
    //使用和声明 word 标志相同的方法来声明 numb 和 fork 标志。
    numbPtr := flag.Int("numb", 42, "an int")
    boolPtr := flag.Bool("fork", false, "a bool")
    //用程序中已有的参数来声明一个标志也是可以的。注意在标志声明函数中需要使用该参数的指针。
    var svar string
    flag.StringVar(&svar, "svar", "bar", "a string var")
    //所有标志都声明完成以后,调用 flag.Parse() 来执行命令行解析。

    2、flag参数解析

    1
    flag.Parse()//将接收到的值解析到对应绑定参数上

    3、得到解析后的参数

    1
    2
    3
    4
    5
    6
    7
    //这里我们将仅输出解析的选项以及后面的位置参数。注意,我们需要使用类似 *wordPtr 这样的语法来对指针解引用,从而得到选项的实际值。
    fmt.Println("word:", *wordPtr)
    fmt.Println("numb:", *numbPtr)
    fmt.Println("fork:", *boolPtr)
    fmt.Println("svar:", svar)
    fmt.Println("tail:", flag.Args())

  • 运行
    1
    2
    3
    4
    5
    6
    ➜  go run flag_1.go -fork=true -numb 1000 -word hello_word -svar test
    word: hello_word
    numb: 1000
    fork: true
    svar: test
    tail: []