Go语言flag包可解析命令行参数,支持字符串、整型、布尔等类型,通过flag.StringVar、flag.BoolVar等定义参数,flag.Parse()解析输入,支持默认值与帮助信息生成,可用于构建带子命令的命令行工具。
Go语言标准库中的
flag
包提供了简单高效的方式来解析命令行参数,适合构建命令行工具。它支持布尔、整型、字符串等常见类型,并能自动生成帮助信息。
基本用法:定义和解析参数
使用
flag
库需要先定义参数变量,然后调用
flag.Parse()
解析命令行输入。
示例:定义一个字符串和一个布尔参数:
flag.StringVar(&name, “name”, “World”, “姓名”) flag.BoolVar(&verbose, “verbose”, false, “是否开启详细日志”) flag.Parse()
这段代码定义了:
立即学习“go语言免费学习笔记(深入)”;
- name:字符串类型,默认值为”World”,可通过
-name=alice
或
-name alice
设置
- verbose:布尔类型,默认false,使用
-verbose
开启(无需赋值)
调用
flag.Parse()
后,这些变量就被正确赋值了。
支持的参数类型
flag
支持多种基础类型,常用方式包括:
- StringVar:字符串
- IntVar:整数
- BoolVar:布尔值
- Float64Var:浮点数
也可以直接返回指针:
port := flag.Int(“port”, 8080, “服务端口”)
这时
port
是指向int的指针,使用时需
*port
取值。
子命令与更复杂结构
如果工具包含多个子命令(如
git clone
,
git commit
),可以用程序逻辑分发。
例如判断第一个参数:
flag.Parse() args := flag.Args() if len(args) switch args[0] { case “start”: handleStart() case “stop”: handleStop() default: log.Fatalf(“未知命令: %s”, args[0]) }
每个子命令可有自己的
flag.FlagSet
来独立解析参数。
自定义用法提示
默认帮助信息可通过
flag.Usage
自定义:
flag.Usage = func() { fmt.Println(“Usage: mytool [options]”) fmt.Println(“Options:”) flag.PrintDefaults() }
当用户输入非法参数或使用
-h
/
--help
时会触发。
基本上就这些。用
flag
实现配置解析不复杂但容易忽略细节,比如参数顺序和类型匹配。只要定义清楚,就能快速搭建出可用的命令行工具。
评论(已关闭)
评论已关闭