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