kingpin 包

概述

  • 大体上与 flag 包相同, flag 包使用
  • 支持非标识符的传参

方法清单

  • 输出信息
    • kingpin.Version(): 输出版本信息
    • kingpin.FatalIfError(): 如果有报错, 打印错误信息, 并退出
    • kingpin.Fatalf(): 打印错误信息, 并退出
    • kingpin.Errorf(): 打印错误信息, 不退出
    • kingpin.FatalUsage(): 如果有报错, 打印帮助信息
    • kingpin.Usage(): 打印帮助信息
  • 创建参数
    • kingpin.Arg(): 创建固定参数(按顺序传入, 不需要 --flag 指定)
    • kingpin.Flag(): 创建可选参数
  • 解析参数
    • kingpin.Parse(): 用法同 flag
    • kingpin.MustParse(): Parse() 底层调用的它
  • 其他:
    • kingpin.New()
    • kingpin.ExpandArgsFromFile()
    • kingpin.UsageTemplate()
    • kingpin.Command()
    • kingpin.HelpFlag.Short('h'): 启动 -h

接收类型

  • 按接收方式分(以string类型为例)
    • kingpin.Flag().String(): 直接指针接收
    • kingpin.Flag().StringVar(): 先创建变量, 用该变量指针接收
  • 按类型分(不同类型有不同的方法, 以string为例)
    • kingpin.Flag().String()
    • kingpin.Flag().Strings(): 以 []string 接收, 接收值为多个时, 必选参数只能有一个, 否则无法区分
    • kingpin.Flag().StringMap(): 以 map[string]string 类型接收
    • 其他类型可能没有 map, 如 Bool()BoolList()

限制

  • kingpin.Flag().Required().String(): 必传
  • kingpin.Flag().IP(): ip 格式
  • kingpin.Flag().Duration(): 时间格式, 10s, 2m, 3h
  • kingpin.Flag().Short(): 设置短参数
  • kingpin.Flag().Default(): 设置默认值
  • kinpin.Flag().Envar(): 使用环境变量

示例

package main

import (
	"fmt"
	"gopkg.in/alecthomas/kingpin.v2"
)

func main() {

	// 必须为 IP 格式
	ip := kingpin.Flag("ip", "IP addr").IP()

	// 必传
	pwd := kingpin.Flag("pwd", "Password").Required().String()

	// Int 类型
	hostID := kingpin.Flag("hostID", "HostID").Int()

	// time
	time := kingpin.Flag("time", "Time").Duration()

	// 解析
	kingpin.Parse()

	fmt.Println(*ip, *pwd, *hostID, *time)
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值