flag - KerwinKoo/KerwinKoo.github.io GitHub Wiki
flag是标准库中实现的命令行工具,可支持命令行参数格式如下:
-flag xxx (使用空格,一个 - 符号)
--flag xxx (使用空格,两个 - 符号)
-flag=xxx (使用等号,一个 - 符号)
--flag=xxx (使用等号,两个 - 符号)
其中,布尔类型的参数防止解析时的二义性,应该使用等号的方式指定。
1.flag.Xxx(),其中Xxx可以是Int、String等;返回一个相应类型的指针,如:
var ip = flag.Int("age", 1234, "help message for age")
或者:flag.XxxVar(),将flag绑定到一个变量上,如:
var flagvar int
flag.IntVar(&flagvar, "flagname", 1234, "help message for flagname")上面两种方法通用。
其中,int类型可以是十进制、十六进制、八进制甚至是负数;bool类型可以是1, 0, t, f, true, false, TRUE, FALSE, True, False。Duration可以接受任何time.ParseDuration能解析的类型
2.创建自定义flag:
flag.Var(&flagVal, "name", "help message for flagname")
但是这种没有提供默认值,所以默认值就是golang规定的类型零值。
在所有的flag定义完成之后,可以通过调用flag.Parse()进行解析。
fmt.Println("------ Args start ------")
for i, v := range flag.Args() {
fmt.Printf("arg[%d] = (%s).\n", i, v)
}
fmt.Println("------ visit flag start ------")
flag.Visit(func(f *flag.Flag) {
fmt.Println(f.Name, f.Value, f.Usage, f.DefValue)
}) fmt.Println("------ visitAll flag start ------")
flag.VisitAll(func(f *flag.Flag) {
fmt.Println(f.Name, f.Value, f.Usage, f.DefValue)
})
fmt.Println("------ PrintDefaults start ------")
flag.PrintDefaults()
fmt.Println("------ PrintDefaults end ------")
fmt.Println("parsed? = ", flag.Parsed())