go cobra包

最近看了几个开源项目,都是基于cobra创建的项目,如果对cobra不了解的话,对整个项目的代码阅读难度都相应的要增加。

首先,cobra是什么?

cobra既是一个用来创建强大的现代CLI命令行的golang库,也是一个生成程序应用和命令行文件的程序。

Cobra提供的功能

1、简易的子命令行模式,如app server、app get等

2、完全兼容posix命令行模式

3、支持全局、局部、串联flags

4、使用cobra很容易生成应用程序和命令,使用cobra create和cobra cmdname

5、如果命令输入有错误,将提供只能建议,如app gt,将提示gt不存在,是否是app get

6、自动生成详细的help信息,如app help

7、自动识别-h,--help和帮助flag

8、自动生成应用程序在bash下命令自动改完成功能

9、自动生成应用程序的man手册

10、命令行别名

11、自定义help和usage信息

12、可选的紧密集成的viper apps

上面的描述稍微有点抽象,下面结合例子讲下cobra如何做的。

首先,通过go get下载cobra

go get -v github.com/spf13/cobra/cobra

然后安装go install。

至此cobra工具安装完成。

在命令行下运行下cobra命令

看到上述信息,说明cobra安装成功。接下来就可以使用cobra了。

假设我们现在要开发一个基于CLI的命令程序,名字的demo。如下图操作:

创建初始化程序

然后就会在gopath目录下创建一个cobra_demo目录。其内部的目录结构如下:

▾ cobra_demo

    ▾ cmd/

        root.go

    main.go

如果此时cobra_demo程序没有subcommands,那么cobra生成应用程序的操作就结束了。

功能基本在root.go文件中,内容如下:

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.`,

    // Run: func(cmd *cobra.Command, args []string) { },

}

func Execute() {

    if err := rootCmd.Execute(); err != nil {

        fmt.Println(err)

        os.Exit(1)

    }

}

func init() {

    cobra.OnInitialize(initConfig)

    rootCmd.PersistentFlags().StringVar(&cfgFile, "config", "", "config file (default is $HOME/.demo.yaml)")

    rootCmd.Flags().BoolP("toggle", "t", false, "Help message for toggle")

    rootCmd.Flags().StringVarP(&name, "name", "n", "", "person's name")

}

// 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())

    }

}

上述的代码是没有经过任何修改的。可以直接运行下看看。下面将上面的代码进行下简单的修改,将 &cobra.Command{}中注释了的代码放开,修改如下:

增加相应的Show方法:

然后运行如下:

至此,cobra的简单介绍完了。

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 点击跳转页面: 类似a标签: onclick="localtion.href='www.baidu.com'"
    i_木木木木木阅读 3,101评论 0 0
  • 五字串联写读后感:引概议联结欢乐来自苦难 成功源于坚持——《贝多芬传》读后感金色的九月,慵懒的阳光透过窗子,照着一...
    为为道来阅读 2,490评论 0 0
  • 曾经小小的家 不是小小的家 在我眼中那么大 够我撒欢和胡闹 空荡荡的床头摆放着 爸爸妈妈的婚纱照 我来了 却不再见...
    胖森丘尼奥阅读 1,001评论 0 0
  • 如果你对周转的任何事物感到不舒服,那是你的感受所造成的,并非事物本身如此。借着感受的调整,可在任何时刻都振奋起来。...
    子瑜曰阅读 5,993评论 0 1