Go 语言 flag 包是轻量级命令行参数解析工具,支持字符串/整数/布尔等类型声明、短长选项、自定义 Value 接口、帮助信息定制及错误处理。
Go 语言内置的 flag 包是解析命令行参数最常用、最轻量的方式,适合大多数 CLI 工具开发场景。它不依赖第三方库,语法简洁,且能自动生成帮助信息。
通过 flag.String、flag.Int、flag.Bool 等函数声明参数变量,再调用 flag.Parse() 解析命令行输入。
flag.String("name", "default", "help message") 返回一个指向字符串的指针,值为用户传入的参数或默认值"name")对应命令行中的 -name value 或 --name=value
flag 默认支持短选项(如 -f)和长选项(如 --file),只需分别调用两次声明即可:
filePtr := flag.String("f", "", "input file (short form)")flag.StringVar(filePtr, "file", "", "input file (long form)")./app -f config.yaml 和 ./app --file=config.yaml 效果一致当需要校验格式(如邮箱、端口号)、累加多个值(如 -v -v -v 表示 debug 级别),可实现 flag.Value 接口或使用 flag.Var() 注册自定义变量。
立即学习“go语言免费学习笔记(深入)”;
var files []string,配合自定义 Set 方法追加值flag.Parse() 后手动遍历 flag.Args() 获取非标志位参数(如文件路径列表)调用 flag.Usage = func() { ... } 可自定义帮助输出;默认情况下,传入 -h 或 --help 会触发 flag.PrintDefaults()。
flag.Parse() 会自动打印错误并调用 os.Exit(2)
flag.CommandLine.SetOutput(ioutil.Discard) 拦截输出,再手动检查main() 开头尽早调
用 flag.Parse(),避免逻辑错乱