GO标准库之flag的基本使用
flag包实现了命令行参数的解析,让我们使用命令行参数更加方便。
这里并不会牵涉到flag包的源码,仅仅总结其常见用法以及注意事项,想更深了解flag解析的原理,自己查看文档https://studygolang.com/static/pkgdoc/pkg/flag.htm 或者ide
直接进入源码查看。
导入flag包
1 | import flag |
flag支持的参数类型
flag包支持的命令行参数类型有bool
、int
、int64
、uint
、uint64
、float
float64
、string
、duration
。
flag参数 | 有效值 |
---|---|
字符串flag | 合法字符串 |
整数flag | 1234 、0664 、0x1234 等类型,也可以是负数。 |
浮点数flag | 合法浮点数 |
bool 类型flag | 1 , 0 , t , f , T , F , true , false , TRUE , FALSE , True , False 。 |
时间段flag | 任何合法的时间段字符串。如”300ms “、”-1.5h “、“2h45m ”。合法的单位有”ns “、“us ” /“µs ”、“ms ”、“s”、“m ”、“h”。 |
定义命令行flag参数
有以下两种常用的定义命令行flag
参数的方法。
flag.Type()
基本格式如下:
flag.Type(flag名, 默认值, 帮助信息)*Type
例如我们要定义姓名、年龄、婚否三个命令行参数,我们可以按如下方式定义:
1 | name := flag.String("name", "张三", "姓名") |
需要注意的是,此时name
、age
、married
、delay
均为对应类型的指针。
flag.TypeVar()
基本格式如下: flag.TypeVar(Type指针, flag名, 默认值, 帮助信息)
例如我们要定义姓名、年龄、婚否三个命令行参数,我们可以按如下方式定义:
1 | var name string |
flag.Parse()
通过以上两种方法定义好命令行flag参数后,需要通过调用flag.Parse()
来对命令行参数进行解析。
支持的命令行参数格式有以下几种:
-flag xxx
(使用空格,一个-
符号)--flag xxx
(使用空格,两个-
符号)-flag=xxx
(使用等号,一个-
符号)--flag=xxx
(使用等号,两个-
符号)
其中,布尔类型的参数必须使用等号的方式指定。
Flag解析在第一个非flag参数(单个”-“不是flag参数)之前停止,或者在终止符”–“之后停止。
flag其他函数
1 | flag.Args() ////返回命令行参数后的其他参数,以[]string类型 |
完整示例
定义
1 | func main() { |
使用
命令行参数使用提示:
1 | >main.exe -help |
注意:win下编译的
exe
,linux
下直接main -help
即可
正常使用命令行flag参数:
1 | >main.exe --username 张翠山 -age 22 --active=false -d=39m -fans=999 |
注意:上述参数中有一个参数为d的,其原始定义里使用的是
onlineTime := flag.Duration("d", 0, "在线时长")
参数名与变量名并不一致,实际携带参数名应为flag定义的参数名,即d
非法使用命令行flag参数1:
1 | >main.exe --username 张翠山 -age 22 --active=false -d=39m -aa=cc bb=dd ee ff |
我们携带了未定义的参数
aa
,所以直接报错。
非法使用命令行flag参数2:
1 | >main.exe --username 张翠山 -age 22 --active=false -d=39m aa=bb cc dd |
上述未携带fans,故fans使用了默认值:0;
aa=bb
、cc
、dd
都当成了一个独立的参数,且因为不管aa=bb
还是cc
、dd
都不是我们正确使用flag参数的方式,所以这里把他当成了其他参数。
非法使用命令行flag参数3:
1 | >main.exe --username 张翠山 -age 22 --active=false aa=bb -d=39m cc -fans 999 |
上述使用方式,将不合格的参数使用
aa=bb
和cc
,导致非法参数前的flag参数都能正常解析,收个非法参数之后的所有合法参数也不会正常解析了,都当成一个其他参数来处理了
综上所述:使用flag,就要合法的使用flag规定的参数定义方式才能够正常解析。
突然发现之前系列文档里有这个的使用说明:【Go入门指南系列-XII-IV-从命令行读取参数】,汗汗汗……
文献来源:https://liwenzhou.com/posts/Go/flag/