GO标志无法正确解析

时间:2020-06-11 21:48:37

标签: go

我现在有一个非常基本的CLI应用程序,可以使用flag库。它接受两个标志,并简单地将值打印到终端上

$ ./hello --flag1 v1 --flag2 v2
v1
v2

如果说我不小心设置了flag2,但忘记提供该值,则它预期显示一条错误消息

$ ./hello --flag1 v1 --flag2
flag needs an argument: -flag2
Usage of ./hello:
  -flag1 string
        usage1 (default "value1")
  -flag2 string
        usage3 (default "value2")

但是,如果我设置flag1,不为其提供值,然后设置flag2,则没有错误

$ ./hello --flag1 --flag2 v2
--flag2
value2

让我感到奇怪的是,flag1会使用flag2的名称作为值,更不用说flag2甚至没有获得所提供的值。我希望结果是类似于设置flag2且未提供任何值的错误消息。

这是图书馆的限制吗?还是这是一个错误?

是否有办法使其正确解析,还是我必须添加自己的自定义解析逻辑?

要复制的最小代码:

package main

import (
    "flag"
    "fmt"
)

func main() {

    flag1 := flag.String("flag1", "value1", "usage1")
    flag2 := flag.String("flag2", "value2", "usage3")

    flag.Parse()

    fmt.Println(*flag1)
    fmt.Println(*flag2)
}

1 个答案:

答案 0 :(得分:1)

如果希望""为空字符串,则必须使用flag2对其进行显式设置。

$ ./hello --flag1 v1 --flag2 ""

对于另一个问题,当您指定flag1时,后面的所有内容都是字符串值。所以当您使用时听起来并不奇怪

$ ./hello --flag1 --flag2

然后flag1的值为“ flag2”,因为它与您这样写的相同:

$ ./hello --flag1="--flag2"

顺便说一句,您不必为其指定值的标志类型为bool。仅将标志指定为true就足够了。