### 简介
`kingpin` 功能比 `flag` 库强大,用法差不多。
相比 `flag` 库,最重要的一点就是支持不加 `-` 的调用。
比如一个命令行程序有三个函数分别为 `A` , `B` , `C` ,要实现根据命令行的输入运行不同的函数,如果用flag实现的话应该是下面这种使用方法:
``` BASH
./cli --method A
./cli --method B
./cli --method C
```
每次都需要输入 `--method` ,然而用 `kingpin` 库实现的话就可以达到下面这种效果:
``` BASH
./cli A
./cli B
./cli C
```
节省了很多输入操作。
### 使用方法
``` BASH
go get gopkg.in/alecthomas/kingpin.v2
go mod vendor
```
这样子 `go.mod` 文件里就引入了, `vendor` 文件夹就缓存了此包,然后直接在代码中使用。
``` Go
package main
import (
"fmt"
"gopkg.in/alecthomas/kingpin.v2"
"net/http"
)
func main() {
var (
listenAddress = kingpin.Flag(
"web.listen-address",
"Address on which to expose metrics and web interface.",
).Default(":18001").String()
metricsPath = kingpin.Flag(
"web.telemetry-path",
"Path under which to expose metrics.",
).Default("/metrics").String()
)
kingpin.HelpFlag.Short('h')
kingpin.Parse()
conf.ApiMtncUrl = *apiMtncPath
http.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) {
w.Write([]byte(`<html>
<head><title>Node Exporter</title></head>
<body>
<h1>xxx Exporter</h1>
<p><a href=" ` + *metricsPath + ` ">Metrics</a></p>
</body>
</html>`))
})
http.Handle("/metrics", XXXX.Handler())
if err := http.ListenAndServe(*listenAddress, nil); err != nil {
fmt.Printf("Error occur when start server %v", err)
}
}
```
官方文档参考 [package kingpin
](http://godoc.org/gopkg.in/alecthomas/kingpin.v2)
### 引用
[Golang命令行参数解析库kingpin](https://xuanyu.li/2017/08/05/golang-cli-args-parse/)
- 安装与下载
- 投稿大纲
- 第一章、跑起来
- 为什么要学 go 语言?
- 让你的 Golang 项目在 IDE 里跑起来
- 第一个 go 程序
- go mod最佳实践
- 第二章、语言基础
- 声明【变量】的各种方式
- 常量+各种类型转换
- switch和type switch
- 循环语句的多种形式、死循环、break/continue
- range深度解析
- 第三章、函数和容器
- 函数简单使用和基本知识解析
- 匿名函数和闭包
- 可变参数
- 集合(map)
- 数组和切片
- 切片知识补充
- 第四章、指针、结构体、接口和异常处理
- 指针讨论
- 结构体
- 接口与多态
- 异常处理
- 第五章、再学一点运用自如
- 其他常用操作
- Go文件操作大全
- Go代码基本标准规范
- 切片排序sort包的使用
- Golang打镜像Dockerfile的写法
- 等待goroutine完成任务,循环中使用goroutine
- kinping.flag包读取命令行配置