Cobra是一个用于建立强大的现代CLI应用程序的库,也是一个用于生成应用程序和命令文件的程序。git
Cobra用于许多Go项目,如Kubernetes、Hugo和Github CLI等。此列表包含了使用Cobra的更普遍的项目列表。github
https://github.com/spf13/cobrashell
Cobra是一个库,提供了一个简单的界面来建立功能强大的现代CLI界面,相似于git&go工具。windows
Cobra仍是一个应用程序,它将生成您的应用程序框架以快速开发基于Cobra的应用程序。bash
眼镜蛇提供:服务器
app server
,app fetch
等。cobra init appname
&cobra add cmdname
app srver
……是您的意思app server
吗?)-h
,--help
等等。Cobra创建在命令,参数和标志的结构上。app
命令表明动做,Args是事物,Flags是这些动做的修饰符。框架
最好的应用程序在使用时读起来就像句子,结果,用户直观地知道如何与之交互。函数
遵循的模式是 APPNAME VERB NOUN --ADJECTIVE.
或 APPNAME COMMAND ARG --FLAG
工具
一些真实的例子能够更好地说明这一点。
在如下示例中,“服务器”是命令,“端口”是标志:
hugo server --port=1313
在此命令中,咱们告诉Git克隆url的内容。
git clone URL --bare
使用眼镜蛇很容易。首先,使用go get
来安装该库的最新版本。此命令将安装cobra
生成器可执行文件以及库及其依赖项:
go get -u github.com/spf13/cobra
Next, include Cobra in your application:
import "github.com/spf13/cobra"
欢迎您提供本身的组织,可是一般基于Cobra的应用程序将遵循如下组织结构:
▾ appName/ ▾ cmd/ add.go your.go commands.go here.go main.go
在Cobra应用程序中,一般main.go文件很是裸露。它有一个目的:初始化眼镜蛇
package main import ( "{pathToYourApp}/cmd" ) func main() { cmd.Execute() }
建立root.go
文件,定义一个基命令
package cmd import ( "github.com/spf13/cobra" ) var RootCmd = &cobra.Command{ Use: "gonne", Run: func(cmd *cobra.Command, args []string) { if len(args) == 0 { cmd.Help() return } }, }
在main函数中使用命令,就是这么简单
main.go
文件
package main import ( "demo-practice/cobra/cmd" "fmt" "os" ) func main() { if err := cmd.RootCmd.Execute(); err != nil { fmt.Println(err) os.Exit(1) } }
在windows环境下编译
go build -o gonne.exe
执行命令查看效果,输出内容以下所示
gonne.exe
Usage:
gonne [flags]
gonne [command]Available Commands:
help Help about any command
version Print the version number of GonneFlags:
-h, --help help for gonneUse "gonne [command] --help" for more information about a command.
在基命令上增长子命令也至关简单,根本无需在基命令和main方法中写任何代码,只需新建一个go文件,多个子命令间也是相互独立的,多么优雅的代码,告别各类case
增长一个版本命令用法:
在cmd目录下增长一个version.go文件,内容以下
package cmd import "github.com/spf13/cobra" func init() { RootCmd.AddCommand(versionCmd) } var versionCmd = &cobra.Command{ Use: "version", Short: "Print the version number of Gonne", Run: func(cmd *cobra.Command, args []string) { println("gonne version is 0.0.1") }, }
init()函数将此命令添加到基命令下
编译后执行 gonne version
gonne version is 0.0.1