Golang如何解析命令行参数_Go flag基础语法使用

Go语言通过flag包实现命令行参数解析,支持字符串、整数、布尔等类型。1. 使用flag.Type(name, defaultVal, usage)定义参数,如port和debug;需调用flag.Parse()解析。2. 原生支持Int、Uint、Float64、String、Bool等类型。3. 通过flag.Var绑定自定义类型,需实现flag.Value接口,适用于切片等复杂类型。4. 非flag参数可用flag.Args()获取,适用于文件名等额外输入。flag包简洁高效,适合标准命令行工具开发,参数以-或--开头,布尔值可省略赋值。

Go语言通过标准库中的flag包提供了命令行参数解析功能,使用简单且类型安全。你可以用它来定义字符串、整数、布尔等类型的参数,并自动处理输入解析和帮助信息生成。

1. 基本语法:定义和使用flag

使用flag.Type系列函数可以定义不同类型的命令行参数,格式为:

flag.Type(name, defaultVal, usage)

其中:

  • name:参数名(如 -port)
  • defaultVal:默认值
  • usage:该参数的说明,用于生成帮助文档

定义完成后需调用flag.Parse()开始解析。

例如定义一个端口号和是否开启调试模式:
var port = flag.Int("port", 8080, "指定服务监听端口")
var debug = flag.Bool("debug", false, "启用调试模式")

func main() {
    flag.Parse()
    fmt.Printf("端口: %d, 调试模式: %v\n", *port, *debug)
}

运行程序时传参:go run main.go -port=9000 -debug,输出结果为:端口: 9000, 调试模式: true

2. 支持的参数类型

flag包原生支持以下几种基本类型:

  • Int / Int64:整型
  • Uint / Uint64:无符号整型
  • Float64:浮点数
  • String:字符串
  • Bool:布尔值

每种类型都有对应的变量定义方式,比如:

var name = flag.String("name", "guest", "用户名称")
var rate = flag.Float64("rate", 1.5, "处理速率")

3. 自定义变量绑定(使用Var方法)

如果你想将参数绑定到已有变量,或支持自定义类型,可使用flag.Var

目标类型需要实现flag.Value接口:

type Value interface {
    String() string
    Set(string) error
}
示例:定义一个支持逗号分隔的字符串切片参数:
type sliceValue []string

func (s *sliceValue) String() string {
    return fmt.Sprintf("%v", []string(*s))
}

func (s *sliceValue) Set(value string) error {
    *s = append(*s, strings.Split(value, ",")...)
    return nil
}

var tags sliceValue
flag.Var(&tags, "tag", "添加标签,可多次使用")

func main() {
    flag.Parse()
    fmt.Println("标签:", tags) // 输入 -tag=a,b -tag=c 得到 [a b c]
}

4. 非flag参数与Parse后的处理

flag.Parse()之后,所有不属于flag的参数会被保留在“剩余参数”中,可通过flag.Args()获取全部,或用flag.NArg()flag.Arg(i)访问单个。

func main() {
    flag.Parse()
    fmt.Println("额外参数数量:", flag.NArg())
    for i, arg := range flag.Args() {
        fmt.Printf("参数[%d]: %s\n", i, arg)
    }
}

例如执行:go run main.go -port=8080 file1.txt file2.txt,则两个文件名会作为额外参数被读取。

基本上就这些。flag包简洁实用,适合大多数命令行工具开发场景,无需引入第三方库即可完成规范的参数解析。注意参数必须以---开头,布尔类型可省略值(如-debug表示true),不复杂但容易忽略细节。