日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Go命令行库Cobra的使用

發布時間:2024/4/11 编程问答 38 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Go命令行库Cobra的使用 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

點擊上方“朱小廝的博客”,選擇“設為星標

回復”1024“獲取獨家整理的學習資料

?

歡迎跳轉到本文的原文鏈接:https://honeypps.com/golang/go-command-lib-cobra-guide/

?

這篇文章是分析golang中命令行解析庫的。關注我公眾號的很多都是Java程序員,對于Java而言,有很多命令行解析庫,如:JOpt Simple、Commons CLI、JCommander,javaer也可以看看類比一下兩種語言不同解析的差異。

?

Cobra在golang項目里面應用非常的廣泛,比如kubernetes、docker、openshift、Hugo等都用到了Cobra,如果要熟悉這些go開源項目實現的話,Cobra是必不可少的掌握項。

?

Cobra既是用于創建強大的現代CLI應用程序的庫,也是用于生成應用程序和命令文件的程序。

?

Cobra提供的功能:

  • 簡易的子命令行模式,如 app server, app fetch等等

  • 完全兼容posix命令行模式

  • 嵌套子命令subcommand

  • 支持全局,局部,串聯flags

  • 使用Cobra很容易的生成應用程序和命令,使用cobra create appname和cobra add cmdname

  • 如果命令輸入錯誤,將提供智能建議,如 app srver,將提示srver沒有,是否是app server

  • 自動生成commands和flags的幫助信息

  • 自動生成詳細的help信息,如app help

  • 自動識別-h,--help幫助flag

  • 自動生成應用程序在bash下命令自動完成功能

  • 自動生成應用程序的man手冊

  • 命令行別名

  • 自定義help和usage信息

  • 可選的緊密集成的viper?apps

?

(Cobra是眼鏡蛇的意思。Steve Francia這位大佬取名真是diao,還有個項目叫viper。。)

Cobra是建立在結構的命令、參數和標志之上。命令(Commands)代表操作,參數(Args)和標志(Flags)是這些行動的修飾符。最好的應用程序就像讀取句子。用戶會知道如何使用本機應用程序,因為他們將理解如何使用它。

要遵循的模式是

APPNAME VERB NOUN --ADJECTIVE

APPNAME COMMAND ARG --FLAG

命令是應用程序的中心點。應用程序支持的每個交互都將包含在命令中。命令可以具有子命令并可選地運行動作。

標志是一種修改命令行為的方法。Cobra支持完全符合POSIX標準的標志以及Go 標志包。Cobra命令可以定義持久保存到子命令和標志的標志,這些命令和標志僅對該命令可用。標志功能由pflag庫提供,pflag庫是標準庫的一個分支,它在添加POSIX兼容性時保持相同的接口。

Github地址:?https://github.com/spf13/cobra

使用

安裝cobra

使用Cobra很簡單。首先,使用go get安裝最新版本

go?get?github.com/spf13/cobra/cobra

由于各種問題,國內使用 go get 安裝 golang 官方包可能會失敗。如果出現:

hidden@hidden:~$?go?get?github.com/spf13/cobra/cobra package?golang.org/x/sys/unix:?unrecognized?import?path?"golang.org/x/sys/unix"?(https?fetch:?Get?https://golang.org/x/sys/unix?go-get=1:?dial?tcp?216.239.37.1:443:?connect:?connection?timed?out) package?golang.org/x/text/transform:?unrecognized?import?path?"golang.org/x/text/transform"?(https?fetch:?Get?https://golang.org/x/text/transform?go-get=1:?dial?tcp?216.239.37.1:443:?connect:?connection?timed?out) package?golang.org/x/text/unicode/norm:?unrecognized?import?path?"golang.org/x/text/unicode/norm"?(https?fetch:?Get?https://golang.org/x/text/unicode/norm?go-get=1:?dial?tcp?216.239.37.1:443:?connect:?connection?timed?out)

即使使用代理也不行,怎么解決這個問題?

其實 golang 在 github 上建立了一個鏡像庫,如 https://github.com/golang/sys/, 即是 https://golang.org/x/sys/ 的鏡像庫。要避免以上報錯,其實只需要執行以下步驟:

mkdir?-p?$GOPATH/src/golang.org/x cd?$GOPATH/src/golang.org/x git?clone?https://github.com/golang/sys git?clone?https://github.com/golang/text

然后再執行go get github.com/spf13/cobra/cobra即可。

安裝成功之后會生成一個名為cobra的可執行文件:

hidden@hidden:~$?ls?-al?$GOPATH/bin?|?grep?cobra -rwxr-xr-x?1?zhuzhonghua?zhuzhonghua?11411056?Aug?12?15:48?cobra

使用Cobra生成應用程序

假設現在我們要開發一個基于CLI的命令程序,名字為demo。執行如下命令:

hidden@hidden:~$?cd?$GOPATH/src/github.com/spf13/ hidden@hidden:~/go/src/github.com/spf13$?cobra?init?demo?--pkg-name=github.com/spf13/demo Your?Cobra?applicaton?is?ready?at /home/zhuzhonghua/go/src/github.com/spf13/demohidden@hidden:~/go/src/github.com/spf13$?cd?demo/

在$GOPATH/src/github.com/spf13目錄下會生成一個demo的文件夾,結構如下:

hidden@hidden:~/go/src/github.com/spf13/demo$?tree . ├──?cmd │???└──?root.go ├──?LICENSE └──?main.go1?directory,?3?files

在demo目錄下會有如下的內容:

hidden@hidden:~/cobra/demo$?tree . ├──?cmd │???└──?root.go ├──?LICENSE └──?main.go1?directory,?3?files

測試cobra效果:

hidden@hidden:~/cobra/demo$?go?run?main.go A?longer?description?that?spans?multiple?lines?and?likely?contains examples?and?usage?of?using?your?application.?For?example:Cobra?is?a?CLI?library?for?Go?that?empowers?applications. This?application?is?a?tool?to?generate?the?needed?files to?quickly?create?a?Cobra?application.subcommand?is?required exit?status?1

在Cobra應用程序中,通常main.go文件非常空洞。它主要只干一件事:初始化Cobra。

package?main//import?"{pathToYourApp}/cmd" import?"github.com/spf13/demo/cmd"func?main()?{cmd.Execute() }

添加子命令

可以定義其他命令,并且通常在cmd/目錄中為每個命令提供自己的文件。

如果要創建版本(version)命令,可以創建cmd/version.go并使用以下內容填充它:

hidden@hidden:~/go/src/github.com/spf13/demo$?cobra?add?version version?created?at?/home/zhuzhonghua/go/src/github.com/spf13/demo

此目錄結構變更為:

hidden@hidden:~/go/src/github.com/spf13/demo$?tree . ├──?cmd │???├──?root.go │???└──?version.go ├──?LICENSE └──?main.go1?directory,?4?files

現在我們來執行以下這個子命令:

hidden@hidden:~/go/src/github.com/spf13/demo$?go?run?main.go?version version?called

生成的version代碼如下(cmd/version.go):

package?cmdimport?("fmt""github.com/spf13/cobra" )//?versionCmd?represents?the?version?command var?versionCmd?=?&cobra.Command{Use:???"version",Short:?"A?brief?description?of?your?command",Long:?`A?longer?description?that?spans?multiple?lines?and?likely?contains?examples and?usage?of?using?your?command.?For?example:Cobra?is?a?CLI?library?for?Go?that?empowers?applications. This?application?is?a?tool?to?generate?the?needed?files to?quickly?create?a?Cobra?application.`,Run:?func(cmd?*cobra.Command,?args?[]string)?{fmt.Println("version?called")}, }func?init()?{rootCmd.AddCommand(versionCmd)//?Here?you?will?define?your?flags?and?configuration?settings.//?Cobra?supports?Persistent?Flags?which?will?work?for?this?command//?and?all?subcommands,?e.g.://?versionCmd.PersistentFlags().String("foo",?"",?"A?help?for?foo")//?Cobra?supports?local?flags?which?will?only?run?when?this?command//?is?called?directly,?e.g.://?versionCmd.Flags().BoolP("toggle",?"t",?false,?"Help?message?for?toggle") }

注:命令的名稱使用駝峰式命名(camelCase),而不能使用蛇形命名(snake_case)。讀者可以自行創建一個蛇形命名的命令來查看一下實際的效果(hint: camelCase to snake_case)。

完善子命令功能

修改上面代碼中的函數Run:

????Run:?func(cmd?*cobra.Command,?args?[]string)?{fmt.Println("version?called")},

修改為:

????Run:?func(cmd?*cobra.Command,?args?[]string)?{fmt.Println("Version?1.0.0?for?demo")},

再次執行go run main.go version,結果如下:

Version?1.0.0?for?demo

另一個示例

在上面的cmd/version.go中我們發現在init函數有這么一行代碼:rootCmd.AddCommand(versionCmd),這個rootCmd是什么呢?

package?cmdimport?("fmt""os""github.com/spf13/cobra"homedir?"github.com/mitchellh/go-homedir""github.com/spf13/viper")var?cfgFile?string//?rootCmd?represents?the?base?command?when?called?without?any?subcommands var?rootCmd?=?&cobra.Command{Use:???"demo",Short:?"A?brief?description?of?your?application",Long:?`A?longer?description?that?spans?multiple?lines?and?likely?contains examples?and?usage?of?using?your?application.?For?example:Cobra?is?a?CLI?library?for?Go?that?empowers?applications. This?application?is?a?tool?to?generate?the?needed?files to?quickly?create?a?Cobra?application.`,//?Uncomment?the?following?line?if?your?bare?application//?has?an?action?associated?with?it://????Run:?func(cmd?*cobra.Command,?args?[]string)?{?}, }//?Execute?adds?all?child?commands?to?the?root?command?and?sets?flags?appropriately. //?This?is?called?by?main.main().?It?only?needs?to?happen?once?to?the?rootCmd. func?Execute()?{if?err?:=?rootCmd.Execute();?err?!=?nil?{fmt.Println(err)os.Exit(1)} }func?init()?{cobra.OnInitialize(initConfig)//?Here?you?will?define?your?flags?and?configuration?settings.//?Cobra?supports?persistent?flags,?which,?if?defined?here,//?will?be?global?for?your?application.rootCmd.PersistentFlags().StringVar(&cfgFile,?"config",?"",?"config?file?(default?is?$HOME/.demo.yaml)")//?Cobra?also?supports?local?flags,?which?will?only?run//?when?this?action?is?called?directly.rootCmd.Flags().BoolP("toggle",?"t",?false,?"Help?message?for?toggle") }//?initConfig?reads?in?config?file?and?ENV?variables?if?set. func?initConfig()?{if?cfgFile?!=?""?{//?Use?config?file?from?the?flag.viper.SetConfigFile(cfgFile)}?else?{//?Find?home?directory.home,?err?:=?homedir.Dir()if?err?!=?nil?{fmt.Println(err)os.Exit(1)}//?Search?config?in?home?directory?with?name?".demo"?(without?extension).viper.AddConfigPath(home)viper.SetConfigName(".demo")}viper.AutomaticEnv()?//?read?in?environment?variables?that?match//?If?a?config?file?is?found,?read?it?in.if?err?:=?viper.ReadInConfig();?err?==?nil?{fmt.Println("Using?config?file:",?viper.ConfigFileUsed())} }

打開cmd/root.go(上面的示例代碼),你會發現rootCmd其實就是我們的根命令。我相信機智的同學已經猜出來我們添加子命令的子命令的方法了。現在讓我們在cmd目錄下新建help.go文件,項目文件結構為:

hidden@hidden:~/go/src/github.com/spf13/demo$?tree . ├──?cmd │???├──?help.go │???├──?root.go │???└──?version.go ├──?LICENSE └──?main.go1?directory,?5?files

其中cmd/help.go的內容為(help為version的子命令):

package?cmdimport?("fmt""github.com/spf13/cobra" )//?versionCmd?represents?the?version?command var?helpCmd?=?&cobra.Command{Use:???"help",Short:?"show?command?info",Long:?`<snip>`,Run:?func(cmd?*cobra.Command,?args?[]string)?{fmt.Println("Here?is?the?help?information")}, }func?init()?{versionCmd.AddCommand(helpCmd)?//注意這里是verisonCmd不是rootCmd }

執行go run main.go version help命令之后,結果為:

hidden:demo?hidden$?go?run?main.go?version?help Here?is?the?help?information

使用Flags

Flags提供了修飾符來控制動作命令的操作。

Persistent Flags:全局性flag, 可用于它所分配的命令以及該命令下的每個命令。在根上分配標志作為全局flag。

Local Flags:局部性flag,在本args分配一個標志,該標志僅適用于該特定命令。

Required flags:必選flag,flag默認是可選的。如果希望命令在未設置flag時報告錯誤,請將其標記為required。

添加Flags

如果仔細看過上面cmd/version.go中init函數中的注釋的話,你應該已經得到了足夠多的信息來自己操作添加flag。

不過這里我再解釋一下,首先是persistent參數,當你的參數作為persistent flag存在時,如注釋所言,在其所有的子命令之下該參數都是可見的。而local flag則只能在該命令調用時執行。

可以做一個簡單的測試,在cmd/version.go的init函數中,添加如下內容(添加在rootCmd.AddCommand(versionCmd)這一行之上):

versionCmd.PersistentFlags().String("global_foo",?"global_val",?"A?help?for?global_foo") versionCmd.Flags().String("local_foo","local_val",?"A?help?for?local_foo")

現在運行go run main.go version -h得到如下結果:

hidden:demo?hidden$?go?run?main.go?version?-h A?longer?description?that?spans?multiple?lines?and?likely?contains?examples and?usage?of?using?your?command.?For?example:Cobra?is?a?CLI?library?for?Go?that?empowers?applications. This?application?is?a?tool?to?generate?the?needed?files to?quickly?create?a?Cobra?application.Usage:demo?version?[flags]demo?version?[command]Available?Commands:help????????show?command?infoFlags:--global_foo?string???A?help?for?global_foo?(default?"global_val")-h,?--help????????????????help?for?version--local_foo?string????A?help?for?local_foo?(default?"local_val")Global?Flags:--config?string???config?file?(default?is?$HOME/.demo.yaml)Use?"demo?version?[command]?--help"?for?more?information?about?a?command.

接著我們對比著再運行go run main.go help -h試試:

hidden:demo?hidden$?go?run?main.go?version?help?-h <snip>Usage:demo?version?help?[flags]Flags:-h,?--help???help?for?helpGlobal?Flags:--config?string???????config?file?(default?is?$HOME/.demo.yaml)--global_foo?string???A?help?for?global_foo?(default?"global_val")

可以發現在Gloabal Flags的變化。version作為root的子命令,仍然可以使用root的persistent flag-> config(可以查看root.go),而help作為test的子命令,不僅可以使用test的persistent flag-> fool, 也可以使用test父命令的persistent flag。從而我們可以直觀的看出persistent的作用范圍是該命令之后的所有子命令。

flag支持的參數類型可以參考文檔:https://godoc.org/github.com/spf13/cobra

注意:cmd.Flags().String()與 cmd.Flags().StringP()是不一樣的。假如我們在version.go的init下增加如下兩行:

versionCmd.Flags().String("flag1","",?"flag1?usage") versionCmd.Flags().StringP("flga2","f","",?"flag2?usage")

前者調用需要如下形式:

go?run?main.go?version?--flag1

后者有如下兩種形式調用:

go?run?main.go?version?--flag2 go?run?main.go?version?-f

其它示例:

persistent flag:

rootCmd.PersistentFlags().BoolVarP(&Verbose, "verbose", "v", false, "verbose output")

local flag:

rootCmd.Flags().StringVarP(&Source, "source", "s", "", "Source directory to read from")

rootCmd.MarkFlagRequired("source") // Flags默認是可選的。如果您希望命令在未設置Flags時報告錯誤,請將其標記為必需

獲取Flags值

在知道了如何設置參數后,我們的下一步當然是需要在運行時獲取改參數的值。現在我們把注意力放到version.go的這個部分:

var?versionCmd?=?&cobra.Command{Use:???"version",Short:?"A?brief?description?of?your?command",Long:?`A?longer?description?that?spans?multiple?lines?and?likely?contains?examples and?usage?of?using?your?command.?For?example:Cobra?is?a?CLI?library?for?Go?that?empowers?applications. This?application?is?a?tool?to?generate?the?needed?files to?quickly?create?a?Cobra?application.`,Run:?func(cmd?*cobra.Command,?args?[]string)?{//待下面的示例插入fmt.Println("Version?1.0.0?for?demo")}, }

讓我們把注意力重新放到上面的代碼上。我們也很容易可以猜測到Use,Short,Long三個參數的作用,這里便不做闡述。

顯而易見,我們應該在Run這里來獲取參數并執行我們的命令功能。獲取參數其實也并不復雜。以versionCmd.Flags().StringP("flag2", "f", "", "flag2 usage")此為例,我們可以在Run函數里添加:

str,_?:=?cmd.Flags().GetString("flag2") fmt.Printf("The?param?vale?is?%s\n",?str)

運行命令go run main.go version -f vvvv,獲得結果如下:

The?param?vale?is?vvvv Version?1.0.0?for?demo

使用Args

可以使用Args字段來指定位置參數的驗證Command。

以下驗證器內置:

  • NoArgs - 如果存在任何位置參數,該命令將報告錯誤。

  • ArbitraryArgs - 該命令將接受任何args。

  • OnlyValidArgs- 如果存在任何不在ValidArgs字段中的位置參數,該命令將報告錯誤Command。

  • MinimumNArgs(int) - 如果沒有至少N個位置參數,該命令將報告錯誤。

  • MaximumNArgs(int) - 如果有多于N個位置參數,該命令將報告錯誤。

  • ExactArgs(int) - 如果沒有確切的N位置參數,該命令將報告錯誤。

  • RangeArgs(min, max) - 如果args的數量不在預期args的最小和最大數量之間,則該命令將報告錯誤。

為了演示Args的用法,我們在cmd目錄下再創建一個args.go文件,其內容如下(注意多了一個Args函數):

mport?("fmt""github.com/pkg/errors""github.com/spf13/cobra" )var?argsCmd?=?&cobra.Command{Use:???"args",Short:?"args?demo",Long:?`<snip>`,Args:?func(cmd?*cobra.Command,?args?[]string)?error?{if?len(args)<1{return?errors.New("requires?at?least?one?arg")}return?nil},Run:?func(cmd?*cobra.Command,?args?[]string)?{fmt.Println("args?called,?args:?",?args)}, }func?init()?{rootCmd.AddCommand(argsCmd) }

示例中限定參數的格式至少為一個否則會報錯。我們來運行一下看一看結果如何,首先是不添加參數(go run main.go args):

hidden:demo?hidden$?go?run?main.go?args Error:?requires?at?least?one?arg Usage:demo?args?[flags]Flags:-h,?--help???help?for?argsGlobal?Flags:--config?string???config?file?(default?is?$HOME/.demo.yaml)requires?at?least?one?arg exit?status?1

可以看到報錯:Error: requires at least one arg。

我們再來試一下添加參數的結果:

hidden:demo?hidden$?go?run?main.go?args?1 args?called,?args:??[1] hidden:demo?hidden$?go?run?main.go?args?1?2?3?4 args?called,?args:??[1?2?3?4]

示例中的Args函數可以替換為

Args:?cobra.MinimumNArgs(1),

讀者可以自行驗證一下效果。

Help命令

前面的示例中出現了cmd/help.go,為了不產生迷惑,我們把這個文件先刪除掉。

當您有子命令時,Cobra會自動為您的應用程序添加一個幫助命令。當用戶運行“app help”時會調用此方法。此外,幫助還將支持所有其他命令作為輸入。比如說,你有一個名為'create'的命令,沒有任何額外的配置; 當'app help create'被調用時,Cobra會工作。每個命令都會自動添加' - help'標志。

可以在終端輸入cobra或者cobra help命令看一下實際的效果:

hidden@hidden:~$?cobra?help Cobra?is?a?CLI?library?for?Go?that?empowers?applications. This?application?is?a?tool?to?generate?the?needed?files to?quickly?create?a?Cobra?application.Usage:cobra?[command]Available?Commands:add?????????Add?a?command?to?a?Cobra?Applicationhelp????????Help?about?any?commandinit????????Initialize?a?Cobra?ApplicationFlags:-a,?--author?string????author?name?for?copyright?attribution?(default?"YOUR?NAME")--config?string????config?file?(default?is?$HOME/.cobra.yaml)-h,?--help?????????????help?for?cobra-l,?--license?string???name?of?license?for?the?project--viper????????????use?Viper?for?configuration?(default?true)Use?"cobra?[command]?--help"?for?more?information?about?a?command.

自定義Help命令

可以提供自定義的help命令或自定義的模板,通過以下函數實現:

cmd.SetHelpCommand(cmd?*Command) cmd.SetHelpFunc(f?func(*Command,?[]string)) cmd.SetHelpTemplate(s?string)

后兩者也適用于子命令。

Usage

當用戶提供無效標志或無效命令時,Cobra會通過向用戶顯示“usage”來做出響應。

示例:

hidden@hidden:~$?cobra?--invalid Error:?unknown?flag:?--invalid Usage:cobra?[command]Available?Commands:add?????????Add?a?command?to?a?Cobra?Applicationhelp????????Help?about?any?commandinit????????Initialize?a?Cobra?ApplicationFlags:-a,?--author?string????author?name?for?copyright?attribution?(default?"YOUR?NAME")--config?string????config?file?(default?is?$HOME/.cobra.yaml)-h,?--help?????????????help?for?cobra-l,?--license?string???name?of?license?for?the?project--viper????????????use?Viper?for?configuration?(default?true)Use?"cobra?[command]?--help"?for?more?information?about?a?command.

自定義Usage

您可以提供自己的使用功能或模板供Cobra使用。與Help一樣,函數和模板可以通過公共方法覆蓋:

cmd.SetUsageFunc(f?func(*Command)?error) cmd.SetUsageTemplate(s?string)

PreRun 和 PostRun鉤子

我們可以在Run方法之前或者之后運行一些其它的方法(函數)。PersistentPreRun和PreRun在Run之前執行。PersistentPostRun和PostRun將Run之后執行。Persistent***Run如果子程序沒有聲明他們自己的功能,他們將繼承這些功能。這些功能按以下順序運行:

PersistentPreRun PreRun Run PostRun PersistentPostRun

下面是使用所有這些功能的兩個命令的示例。執行子命令時,它將運行root命令的PersistentPreRun,但不運行root命令的PersistentPostRun:

import?("fmt""github.com/spf13/cobra" )func?main(){var?rootCmd?=?&cobra.Command{Use:?"root",PersistentPreRun:?func(cmd?*cobra.Command,?args?[]string)?{fmt.Printf("[root]?PersistentPreRun?with?args:?%v?\n",?args)},PreRun:?func(cmd?*cobra.Command,?args?[]string)?{fmt.Printf("[root]?PreRun?with?args:?%v?\n",?args)},Run:?func(cmd?*cobra.Command,?args?[]string)?{fmt.Printf("[root]?Run?with?args:?%v?\n",?args)},PostRun:?func(cmd?*cobra.Command,?args?[]string)?{fmt.Printf("[root]?PostRun?with?args:?%v?\n",?args)},PersistentPostRun:?func(cmd?*cobra.Command,?args?[]string)?{fmt.Printf("[root]?PersistentPostRun?with?args:?%v?\n",?args)},}var?subCmd?=?&cobra.Command{Use:???"sub",PreRun:?func(cmd?*cobra.Command,?args?[]string)?{fmt.Printf("[sub]?PreRun?with?args:?%v?\n",?args)},Run:?func(cmd?*cobra.Command,?args?[]string)?{fmt.Printf("[sub]?Run?with?args:?%v?\n",?args)},PostRun:?func(cmd?*cobra.Command,?args?[]string)?{fmt.Printf("[sub]?PostRun?with?args:?%v?\n",?args)},PersistentPostRun:?func(cmd?*cobra.Command,?args?[]string)?{fmt.Printf("[sub]?PersistentPostRun?with?args:?%v?\n",?args)},}rootCmd.AddCommand(subCmd)rootCmd.SetArgs([]string{""})rootCmd.Execute()fmt.Println()rootCmd.SetArgs([]string{"sub",?"arg1",?"arg2",})rootCmd.Execute() }

運行結果:

[root]?PersistentPreRun?with?args:?[] [root]?PreRun?with?args:?[] [root]?Run?with?args:?[] [root]?PostRun?with?args:?[] [root]?PersistentPostRun?with?args:?[][root]?PersistentPreRun?with?args:?[arg1?arg2] [sub]?PreRun?with?args:?[arg1?arg2] [sub]?Run?with?args:?[arg1?arg2] [sub]?PostRun?with?args:?[arg1?arg2] [sub]?PersistentPostRun?with?args:?[arg1?arg2]

參考資料及衍生讀物

  • Golang: Cobra命令行參數庫的使用【博客園】

  • golang命令行庫Cobra的使用【簡書】

  • Cobra Generator

  • https://golang.org/pkg/flag/

  • https://godoc.org/github.com/spf13/cobra#Command

  • https://github.com/spf13/pflag

  • https://godoc.org/github.com/spf13/cobra

  • github.com/spf13/cobra go cobra包介紹

  • golang命令行庫cobra使用【博客園】

?


歡迎跳轉到本文的原文鏈接:https://honeypps.com/golang/go-command-lib-cobra-guide/

想知道更多?描下面的二維碼關注我

相關推薦:

  • 《科普 | 明星公司之Netflix》

  • 《看我如何作死 | 將CPU、IO打爆》

  • 《看我如何作死 | 網絡延遲、丟包、中斷一個都沒落下》

  • 《7102-2019年技術文全套整理,建議收藏》

  • 《看我如何假死!》

  • 《總結緩存使用過程中的幾種策略以及優缺點組合分析》

?

加技術群入口(備注:技術):>>>Learn More<<

免費資料入口(備注:1024):>>>Learn More<<

免費星球入口:>>>Free<<<

?
點個"在看"唄^_^

總結

以上是生活随笔為你收集整理的Go命令行库Cobra的使用的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 国产精品一区二区三 | 色哟哟无码精品一区二区三区 | 日韩免费视频一区 | 在线欧美a | 最新超碰在线 | 亚洲国产专区 | 在线婷婷 | 黄色特级毛片 | 91香蕉嫩草 | 国产中文字幕在线免费观看 | 色呦呦在线免费观看 | 亚洲国产精品视频 | 成人性生交大片 | 91香蕉在线视频 | 91精品国产乱码久久久久久久久 | 日韩av在线看 | 人妻射精一区二区 | 夜夜高潮夜夜爽 | 亚洲高h | 91视频免费观看 | 亚洲欧洲精品一区二区 | 亚洲欧美日韩在线一区 | 久草视频在线免费播放 | 欧美中文字幕在线播放 | 伊人久久中文 | 懂色av中文字幕 | 国产一线二线三线在线观看 | 国产日韩欧美在线观看 | 美女黄色影院 | 免费 成 人 黄 色 | 91一区视频 | 四虎精品在线 | 日本a级网站 | 日本天堂在线观看 | 欧美一级黄视频 | 在线观看的黄色网址 | 国产乱码在线 | 一区二区三区免费播放 | 男女视频免费观看 | 国产成人午夜精华液 | 你懂的在线观看视频 | 欧美精品久久久久 | 国产区二区 | 你懂的国产| 日本在线网址 | 日本免费一二三区 | 欧美精品一级在线观看 | 欧洲国产视频 | 亚洲 欧美 成人 | 香蕉久久av| 亚洲AV第二区国产精品 | 黄色动漫免费在线观看 | 综合激情网站 | 国产日韩在线免费观看 | 欧美成人精品一区二区免费看片 | 日韩在观看线 | 一区二区三区免费在线 | 91精品国产自产精品男人的天堂 | 自拍偷拍欧美亚洲 | 女人看黄色网 | 国产情侣av自拍 | 亚洲成人a∨ | 亚洲激情视频在线播放 | 久久午夜免费视频 | 国产精品日日摸天天碰 | 91a视频 | 夜夜撸 | 成人综合一区 | 国产老熟女一区二区三区 | 99精品一级欧美片免费播放 | 波多野结衣视频网址 | 国产精品久久久无码一区 | 日韩精品中文字幕在线 | 操干视频 | 亚洲精品国产精品国自产 | 国产在线观看 | 中文字幕精品亚洲 | 91大片在线观看 | 色眯眯网 | 国产精品白嫩极品美女视频 | 中文字幕大全 | 天天玩夜夜操 | 手机在线观看av片 | 欧美性猛交xxxx免费看久久久 | 天堂网一区二区 | 小柔的淫辱日记(1~7) | 北条麻妃在线一区 | 无码人妻精品一区二区中文 | 成人3d动漫一区二区三区91 | 婷婷社区五月天 | 色天使在线视频 | 欧美囗交做爰视频 | av中文资源 | 白白色免费视频 | 高潮av| 色悠悠网址 | 欧美亚洲不卡 | 蜜臀久久精品久久久久久酒店 | 亚洲AV不卡无码一区二区三区 |