Go Flag 使用教程

Flag库

flag库是Go语言标准库之一,提供了命令行参数解析的能力。

官方库文档翻译

参数类型

Go Flag 接受的参数类型

  • bool
  • int
  • int64
  • uint
  • uint64
  • string
  • float64
  • duration

除了以上8个类型外,flag允许用户自定义数据类型,但是该类型必须实现value接口。

使用

flag 会尝试解析绑定的参数,如果发生参数类型不匹配、无法解析等问题,将会导致执行停止。

绑定参数

flag包提供了两种绑定参数的方法

  • type(...args) typePoint

  • typeVar(typePoint, ...args)

    type为基本参数类型

但是对用用户自定义的类型没有type()typeVar()方法,而是Var方法.

type函数

type函数支持: bool int int64 uint uint64 string float64 duration

八种类型的函数定义除了类型不一样外,其他参数都是一样的,具体定义如下:

func Bool(name string, value bool, usage string) *bool
func Int(name string, value int, usage string) *int
func Int64(name string, value int64, usage string) *int64
func Uint(name string, value uint, usage string) *uint
func Uint64(name string, value uint64, usage string) *uint64
func String(name string, value string, usage string) *string
func Float64(name string, value float64, usage string) *float64
func Duration(name string, value time.Duration, usage string) *time.Duration    

函数参数说明:

  • name: 参数名称
  • value: 默认值
  • usage: 使用方法、帮助文档

示例

func main(){
    boolVal := flag.Bool("testBool", false, "testBool is bool type.")
    flag.Parse()
    
    // 如果使用 -testBool作为参数,控制台将会打印 true, 否则打印 false
    fmt.println(boolVal)
}

typeVar函数

typeVar函数支持: bool int int64 uint uint64 string float64 duration

typeVar函数还另外包含了一种特殊的函数Var(),没有类型修饰。该函数用于绑定用户自定义的参数类型。

具体请看示例:

func main(){
    flag.BoolVar(&config.BoolValue, "bool", false, "This is bool value.")
    flag.IntVar(&config.IntValue, "int", 0, "This is int value.")
    flag.Int64Var(&config.Int64Value, "int64", 0, "This is int64 value.")
    flag.UintVar(&config.UintValue, "uint", 0, "This is uint value.")
    flag.Uint64Var(&config.Uint64Value, "uint64", 0, "This is uint64 value.")
    flag.StringVar(&config.StringValue, "string", "", "This is string value.")
    flag.Float64Var(&config.Float64Value, "float64", 0, "This is float64 value")
    flag.DurationVar(&config.DurationValue, "duration", time.Second * 0, "This is duration value.")
    flag.Var(&config.MyValue, "myValue", "This is my value.")
}

更完整的示例请看GoFlag.GO

参数语法

布尔类型

布尔类型为开关类型,后面可以不加参数。

如果不加参数,则一旦出现,默认为true,如果没有出现,则为用户定义的默认数据。

flag.BoolVar(&config.BoolValue, "bool", false, "This is bool value.")
  • 如果使用指令: go run main.go -bool,则config.BoolValue被赋值为:true
  • 如果使用指令: go run main.go,则config.BoolValue为默认值:false
  • 如果修改代码为:
    flag.BoolVar(&config.BoolValue, "bool", true, "This is bool value.")
    
    则使用: go run main.go, config.BoolValue为默认值:true

布尔类型也可以显示声明,格式为-bool=t,t表示true。

bool类型可以接受的值包括:1, 0, t, f, T, F, true, false, TRUE, FALSE, True, False

go run GoFlag.go -bool=t等效于go run GoFlag.go -bool

Int Int64 Uint Uint64类型

四种类型区别不大,可以根据场景决定使用。

对于int int64类型来说,可以接受有效数据包括负数,而uint uint64则不支持负数。

这四种类型可以接受 123, 0x46等数据,但是不支持浮点类型,flag不会对数据进行转换。

同样,如果数据超出了类型的取值返回,数据也会被认为是无效的。

Go int8,16,32,64, uint8,16,32,64取值范围
int8: -128 ~ 127
int16: -32768 ~ 32767
int32: -2147483648 ~ 2147483647
int64: -9223372036854775808 ~ 9223372036854775807
uint8: 0 ~ 255
uint16: 0 ~ 65535
uint32: 0 ~ 4294967295
uint64: 0 ~ 18446744073709551615

不同平台中,int\uint的具体数据不一样,如64位系统中,int = int64, uint = uint64

浮点类型

flag 仅支持一种浮点类型:float64。

float参数 示例

$ go run GoFlag.go -float64 123.123
$ go run GoFlag.go -float64=123.123
$ go run GoFlag.go -float64 123e10

字符串类型

flag 包通过空格(没有被"标记的)进行参数切割,所以如果使用字符串,则在必要的情况下使用"

  • 参数数据中存在空格情况则使用双引号: go run GoFlag.go -string "test 123 ", 此时string的值为test 123
  • 参数数据种没有存在空格,则凭个人喜好使用: go run GoFlag.go -string test 123, 此时string的值为test

时间段类型

flag 可以将time.Duration支持的字符串转换为time.Duration类型。
如:300ms -1.5h 2h45m

有效的时间单位包括:ns, us (or µs), ms, s, m, h.

有关此部分的详细说明请查阅time.ParseDuration相关文档。

自定义类型

自定义的接口体实现了ValueSet(String)error方法,所以在检测到相关绑定数据后,flag包会传入一个字符串,进行解析。

同时,在使用的时候,该参数为数值类型(不是开关类型),需要指定数据。

子命令

flag 包提供了 FlagSet 结构体,用来封装更多形式的参数、命令。

默认使用flag时将会创建一个空的FlagSet。

使用:

func NewFlagSet(name string, errorHandling ErrorHandling) *FlagSet

该函数返回一个FlagSet,如果希望使用该FlagSet,需要手动调用该FlagSetParse()方法进行解析。

示例代码请看GoFlagSet.go

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,053评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,527评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,779评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,685评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,699评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,609评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,989评论 3 396
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,654评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,890评论 1 298
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,634评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,716评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,394评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,976评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,950评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,191评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,849评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,458评论 2 342