You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

5.8 KiB

cobra 概要

1.cobra是一款非常强大、好用的command模式包主要创建非http接口服务。
2.cobra的全方位功能、细节介绍请自行百度搜索,这里主要介绍如何在本项目骨架中快速使用cobra编写程序。

关于 cobra入口、业务目录

1.入口:cmd/command/main.go,主要用于编译。
2.业务代码目录:command/cmd/

cobra 快速使用指南

快速创建模板的方法主要有:
1.复制command/cmd/demo.go基于此模板自行修改。
2.进入command 目录,执行命令 cobra add 业务模块名,也可以快速创建出模板文件。

demo.go 代码介绍

package cmd

import (
	"fmt"
	"github.com/spf13/cobra"
)

// demo示例文件我们假设一个场景
// 通过一个命令指定 搜索引擎(百度、搜狗、谷歌)、搜索类型(文本、图片)、关键词 执行一系列的命令

var (
	// 1.定义一个变量,接收搜索引擎(百度、搜狗、谷歌)
	SearchEngines string
	// 2.搜索的类型(图片、文字)
	SearchType string
	// 3.关键词
	KeyWords string
)

var logger = variable.ZapLog.Sugar()

// 定义命令
var demo = &cobra.Command{
	Use:     "sousuo",
	Aliases: []string{"sou", "ss", "s"}, // 定义别名
	Short:   "这是一个demo以搜索内容进行演示业务逻辑...",
	Long: `调用方法:
				1.进入项目根目录Ginkeleton				2.执行 go  run  cmd/cli/main.go sousuo -h  //可以查看使用指南
				3.执行 go  run  cmd/cli/main.go sousuo 任意参数  // 快速运行一个demo
				4.执行 go  run  cmd/cli/main.go  sousuo -K 关键词  -E  baidu -T img    // 指定参数运行demo
	`,
	//Args:    cobra.ExactArgs(2),  //  限制非flag参数也叫作位置参数的个数必须等于 2 ,否则会报错
	// Run命令以及子命令的前置函数
	PersistentPreRun: func(cmd *cobra.Command, args []string) {
		//如果只想作为子命令的回调,可以通过相关参数做判断,仅在子命令执行
		logger.Infof("Run函数子命令的前置方法位置参数%v flag参数%s, %s, %s \n", args[0], SearchEngines, SearchType, KeyWords)
	},
	// Run命令的前置函数
	PreRun: func(cmd *cobra.Command, args []string) {
		logger.Infof("Run函数的前置方法位置参数%v flag参数%s, %s, %s \n", args[0], SearchEngines, SearchType, KeyWords)

	},
	// Run 命令是 核心 命令,其余命令都是为该命令服务,可以删除,由您自由选择
	Run: func(cmd *cobra.Command, args []string) {
		//args  参数表示非flag也叫作位置参数该参数默认会作为一个数组存储。
		//fmt.Println(args)
		start(SearchEngines, SearchType, KeyWords)
	},
	// Run命令的后置函数
	PostRun: func(cmd *cobra.Command, args []string) {
		logger.Infof("Run函数的后置方法位置参数%v flag参数%s, %s, %s \n", args[0], SearchEngines, SearchType, KeyWords)
	},
	// Run命令以及子命令的后置函数
	PersistentPostRun: func(cmd *cobra.Command, args []string) {
		//如果只想作为子命令的回调,可以通过相关参数做判断,仅在子命令执行
		logger.Infof("Run函数子命令的后置方法位置参数%v flag参数%s, %s, %s \n", args[0], SearchEngines, SearchType, KeyWords)
	},
}

// 注册命令、初始化参数
func init() {
	rootCmd.AddCommand(demo)
	demo.Flags().StringVarP(&SearchEngines, "Engines", "E", "baidu", "-E 或者 --Engines 选择搜索引擎例如baidu、sogou")
	demo.Flags().StringVarP(&SearchType, "Type", "T", "img", "-T 或者 --Type 选择搜索的内容类型,例如:图片类")
	demo.Flags().StringVarP(&KeyWords, "KeyWords", "K", "关键词", "-K 或者 --KeyWords 搜索的关键词")
	//demo.Flags().BoolP(1,2,3,5)  //接收bool类型参数
	//demo.Flags().Int64P()  //接收int型
}

//开始执行
func start(SearchEngines, SearchType, KeyWords string) {

	logger.Infof("您输入的搜索引擎:%s 搜索类型:%s, 关键词:%s\n", SearchEngines, SearchType, KeyWords)

}


运行以上代码


go  run  cmd/cli/main.go  sousuo  测试demo   -E  百度  -T 图片  -K 关键词

// 结果

Run函数子命令的前置方法,位置参数:测试demo flag参数:百度, 图片, 关键词
Run函数的前置方法,位置参数:测试demo flag参数:百度, 图片, 关键词
您输入的搜索引擎:百度, 搜索类型:图片, 关键词:关键词
Run函数的后置方法,位置参数:测试demo flag参数:百度, 图片, 关键词
Run函数子命令的后置方法,位置参数:测试demo flag参数:百度, 图片, 关键词

子命令的定义与使用

package cmd

import (
	"fmt"
	"github.com/spf13/cobra"
)

// 定义子命令
var subCmd = &cobra.Command{
	Use:   "subCmd",
	Short: "subCmd 命令简要介绍",
	Long:  `命令使用详细介绍`,
	Args:  cobra.ExactArgs(1), //  限制非flag参数的个数 = 1 ,超过1个会报错
	Run: func(cmd *cobra.Command, args []string) {
		fmt.Println("测试子命令被嵌套调用:" + args[0])
	},
}

//注册子命令
func init() {
	demo.AddCommand(subCmd)
	// 子命令仍然可以定义 flag 参数,相关语法参见 demo.go 文件
}


运行以上代码


go  run   cmd/cli/main.go sousuo  subCmd  子命令参数

// 结果
Run函数子命令的前置方法,位置参数:子命令参数 flag参数:baidu, img, 关键词
子命令参数
Run函数子命令的后置方法,位置参数:子命令参数 flag参数:baidu, img, 关键词
 

如果文件分布在子目录,创建方式

创建子目录命令