Cobra 명령줄 개발
Question
인터넷에서 코브라에 대한 개발 자료를 많이 찾았는데, 대부분이 공식 웹사이트에서 튜토리얼을 복사해서 사용하는 편이라 프로젝트를 개발한 후, Cobra 개발 튜토리얼을 직접 작성해 보세요.
Cobra 개요
Cobra는 git 및 go 도구와 유사한 강력한 최신 CLI 인터페이스를 만들기 위한 간단한 인터페이스를 제공하는 라이브러리입니다.
Cobra 제공 사항:
간단한 하위 명령 기반 CLI: 앱 서버
,앱 가져오기
등
app server
、app fetch
等。app srver
......你的意思是app server
?)-h
,--help
等的自动帮助标志识别安装
使用 Cobra 很容易。首先,用于go get
앱 서버
...앱 서버
?)🎜🎜명령 및 플래그에 대한 자동 도움말 생성🎜🎜-h ,자동 도움말 플래그 인식 --help
등을 위해.🎜🎜애플리케이션(bash, zsh, fish, powershell)에 대한 쉘 자동 완성 기능을 자동으로 생성합니다.🎜🎜Auto -응용 프로그램에 대한 매뉴얼 페이지 생성🎜🎜명령 별칭을 손상시키지 않고 변경할 수 있음🎜🎜자신만의 도움말, 사용법 등을 정의할 수 있는 유연성 🎜🎜선택 사항 및 바이퍼[1]12요소 애플리케이션을 위한 원활한 통합. 설치
🎜Cobra를 사용하는 것은 쉽습니다. 먼저,가져오기
최신 버전의 라이브러리를 설치합니다. 🎜go get -u github.com/spf13/cobra@latest
import "github.com/spf13/cobra"
用法
使用 cobra 自带的 cli 工具 生成项目
安装 cli 工具
go install github.com/spf13/cobra-cli@latest
使用方式
创建一个新的文件夹 cd
到这个文件夹里面去运行 go mod init <MODNAME>
来创建一个go mod 项目
例如:
cd $HOME/code mkdir myapp cd myapp go mod init github.com/spf13/myapp
初始化 Cobra CLI 应用程序
从 Go 模块中运行 cobra-cli init
。这将创建一个新的基本项目让您修改。
您将需要打开并编辑 cmd/root.go
并提供您自己的描述和逻辑。
例如:
cd $HOME/code/myapp cobra-cli init go run main.go
将命令添加到项目
初始化 cobra 应用程序后,您可以继续使用 Cobra 生成器向您的应用程序添加其他命令。执行此操作的命令是cobra-cli add
.
在您的项目目录(您的 main.go 文件所在的位置)中,您将运行以下命令:
cobra-cli add serve cobra-cli add config cobra-cli add create -p 'configCmd'
其中还有很多标志我这里就不在细说了,需要了解的可以访问 cobra-cli[2] 自行查看。
采用手动进行项目开发
我们先来看一下 cobra 推荐的项目目录结构
▾ appName/ ▾ cmd/ add.go your.go commands.go here.go main.go
并且在main.go 中应该非常的简单:
package main import ( "{pathToYourApp}/cmd" ) func main() { cmd.Execute() }
然后需要创建一个 rootCmd 来当做 命令的入口 (在 cmd/root.go
中)
var rootCmd = &cobra.Command{ Use: "hugo", Short: "Hugo is a very fast static site generator", Long: `A Fast and Flexible Static Site Generator built with love by spf13 and friends in Go. Complete documentation is available at http://hugo.spf13.com`, Run: func(cmd *cobra.Command, args []string) { // Do Stuff Here }, } func Execute() { if err := rootCmd.Execute(); err != nil { fmt.Fprintln(os.Stderr, err) os.Exit(1) } }
您将在 init() 函数中另外定义标志和句柄配置。
package cmd import ( "fmt" "os" "github.com/spf13/cobra" "github.com/spf13/viper" ) var ( // Used for flags. cfgFile string userLicense string rootCmd = &cobra.Command{} ) // Execute executes the root command. func Execute() error { return rootCmd.Execute() } func init() { cobra.OnInitialize(initConfig) rootCmd.PersistentFlags().StringVar(&cfgFile, "config", "", "config file (default is $HOME/.cobra.yaml)") rootCmd.PersistentFlags().StringP("author", "a", "YOUR NAME", "author name for copyright attribution") rootCmd.PersistentFlags().StringVarP(&userLicense, "license", "l", "", "name of license for the project") rootCmd.PersistentFlags().Bool("viper", true, "use Viper for configuration") viper.BindPFlag("author", rootCmd.PersistentFlags().Lookup("author")) viper.BindPFlag("useViper", rootCmd.PersistentFlags().Lookup("viper")) viper.SetDefault("author", "NAME HERE <EMAIL ADDRESS>") viper.SetDefault("license", "apache") rootCmd.AddCommand(addCmd) rootCmd.AddCommand(initCmd) } func initConfig() { if cfgFile != "" { // Use config file from the flag. viper.SetConfigFile(cfgFile) } else { // Find home directory. home, err := os.UserHomeDir() cobra.CheckErr(err) // Search config in home directory with name ".cobra" (without extension). viper.AddConfigPath(home) viper.SetConfigType("yaml") viper.SetConfigName(".cobra") } viper.AutomaticEnv() if err := viper.ReadInConfig(); err == nil { fmt.Println("Using config file:", viper.ConfigFileUsed()) } }
接下来就是开发 配置各种 cobra cmd 的参数,在配置之前,我们先来熟悉一下 cmd 的内容。
type Command struct { // 使用是单行使用消息。 // 推荐的语法如下: // [ ] 标识一个可选参数。未括在括号中的参数是必需的。 // ... 表示您可以为前一个参数指定多个值。 // |表示互斥信息。您可以使用分隔符左侧的参数或分隔符右侧的参数。您不能在一次使用该命令时同时使用这两个参数。 // { } 分隔一组互斥参数,当需要其中一个参数时。如果参数是可选的,则将它们括在方括号 ([ ]) 中。 // 示例:add [-F file | -D dir]... [-f format] profile Use string // Aliases 是一个别名数组,可以用来代替 Use 中的第一个单词。 Aliases []string // SuggestFor 是一个命令名称数组,将为其建议该命令 - 类似于别名,但只是建议。 SuggestFor []string // Short 是“帮助”输出中显示的简短描述。 Short string // Long 是“help <this-command>”输出中显示的长消息。 Long string // Example is examples of how to use the command. Example string // ValidArgs 是 shell 完成中接受的所有有效非标志参数的列表,(提供的自动补全的参数) ValidArgs []string // ValidArgsFunction 是一个可选函数,它为 shell 完成提供有效的非标志参数。 // 它是使用 ValidArgs 的动态版本。只有 ValidArgs 和 ValidArgsFunction 之一可用于命令。 ValidArgsFunction func(cmd *Command, args []string, toComplete string) ([]string, ShellCompDirective) // 判断参数的格式,内置多种验证格式。 Args PositionalArgs // ArgAliases 是 ValidArgs 的别名列表。这些不是在 shell 完成中向用户建议的,但如果手动输入则接受。 ArgAliases []string // BashCompletionFunction 是传统 bash 自动完成生成器使用的自定义 bash 函数。 // 为了与其他 shell 的可移植性,建议改用 ValidArgsFunction BashCompletionFunction string // Deprecated defines, if this command is deprecated and should print this string when used. Deprecated string // Annotations are key/value pairs that can be used by applications to identify or // group commands. Annotations map[string]string // Version defines the version for this command. If this value is non-empty and the command does not // define a "version" flag, a "version" boolean flag will be added to the command and, if specified, // will print content of the "Version" variable. A shorthand "v" flag will also be added if the // command does not define one. Version string // Run 函数按以下顺序执行: // * PersistentPreRun() // * PreRun() // * Run() // * PostRun() // * PersistentPostRun() // 所有函数都获得相同的参数,即命令名称后面的参数。 // // PersistentPreRun: 该命令的子级将继承并执行。 PersistentPreRun func(cmd *Command, args []string) // PersistentPreRunE: 上面的返回错误形式 PersistentPreRunE func(cmd *Command, args []string) error // PreRun: 此命令的子级不会继承。 PreRun func(cmd *Command, args []string) // PreRunE: 上面的返回错误形式 PreRunE func(cmd *Command, args []string) error // Run: 通常是实际的功函数。大多数命令只会实现这一点。 Run func(cmd *Command, args []string) // RunE: 上面返回错误的形式 RunE func(cmd *Command, args []string) error // PostRun: 在 run 命令之后运行。 PostRun func(cmd *Command, args []string) // PostRunE: 上面返回错误的形式。 PostRunE func(cmd *Command, args []string) error // PersistentPostRun: 该命令的子命令将在 PostRun 之后继承并执行。 PersistentPostRun func(cmd *Command, args []string) // PersistentPostRunE: 上面返回错误的形式。 PersistentPostRunE func(cmd *Command, args []string) error ... //FParseErrWhitelist flag parse errors to be ignored FParseErrWhitelist FParseErrWhitelist // CompletionOptions 是一组用于控制 shell 完成处理的选项 (下面给出了对应的结构体) CompletionOptions CompletionOptions ... // TraverseChildren 在执行子命令之前解析所有父项的标志。 TraverseChildren bool // Hidden defines, 如果此命令被隐藏并且不应该出现在可用命令列表中。 Hidden bool ... }
// CompletionOptions are the options to control shell completion type CompletionOptions struct { // DisableDefaultCmd 防止 Cobra 创建默认的“完成”命令 (禁用这么默认的 cmd 命令) DisableDefaultCmd bool // 防止 Cobra 为支持完成描述的 shell 创建“--no-descriptions”标志 DisableNoDescFlag bool // DisableDescriptions 关闭支持它们的 shell 的所有完成描述 DisableDescriptions bool // HiddenDefaultCmd 隐藏默认的“完成”命令 (一般情况下,采用隐藏这个 cmd ) HiddenDefaultCmd bool }
这里大概就看了 Cmd 的大概使用的结构体和字段,在开发的时候对应需要的东西,直接设置对应的值即可。
Short 的描述使用 shell 自动完成提示信息使用。
Long 的描述用于 -h
或 help
打印使用。
生成自动提示命令的功能
具体的操作步骤可以看 生成外壳完成[3]
在这里需要说一句的是:使用命令生成的时候默认是打印在 控制台,需要自己重定义在指定的目录文件中去。
在根据不同的平台终端,配置好这个文件,然后就可以使用 自动提示完成的 功能了。
위 내용은 Cobra 명령줄 개발의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











보안 통신에 널리 사용되는 오픈 소스 라이브러리로서 OpenSSL은 암호화 알고리즘, 키 및 인증서 관리 기능을 제공합니다. 그러나 역사적 버전에는 알려진 보안 취약점이 있으며 그 중 일부는 매우 유해합니다. 이 기사는 데비안 시스템의 OpenSSL에 대한 일반적인 취약점 및 응답 측정에 중점을 둘 것입니다. DebianopensSL 알려진 취약점 : OpenSSL은 다음과 같은 몇 가지 심각한 취약점을 경험했습니다. 심장 출혈 취약성 (CVE-2014-0160) :이 취약점은 OpenSSL 1.0.1 ~ 1.0.1F 및 1.0.2 ~ 1.0.2 베타 버전에 영향을 미칩니다. 공격자는이 취약점을 사용하여 암호화 키 등을 포함하여 서버에서 무단 읽기 민감한 정보를 사용할 수 있습니다.

백엔드 학습 경로 : 프론트 엔드에서 백엔드 초보자로서 프론트 엔드에서 백엔드까지의 탐사 여행은 프론트 엔드 개발에서 변화하는 백엔드 초보자로서 이미 Nodejs의 기초를 가지고 있습니다.

Beegoorm 프레임 워크에서 모델과 관련된 데이터베이스를 지정하는 방법은 무엇입니까? 많은 Beego 프로젝트에서는 여러 데이터베이스를 동시에 작동해야합니다. Beego를 사용할 때 ...

Go Language의 부동 소수점 번호 작동에 사용되는 라이브러리는 정확도를 보장하는 방법을 소개합니다.

Go Crawler Colly의 대기열 스레딩 문제는 Colly Crawler 라이브러리를 GO 언어로 사용하는 문제를 탐구합니다. � ...

Go Language에서 메시지 대기열을 구현하기 위해 Redisstream을 사용하는 문제는 Go Language와 Redis를 사용하는 것입니다 ...

Go Language의 문자열 인쇄의 차이 : println 및 String () 함수 사용 효과의 차이가 진행 중입니다 ...

골란드의 사용자 정의 구조 레이블이 표시되지 않으면 어떻게해야합니까? Go Language 개발을 위해 Goland를 사용할 때 많은 개발자가 사용자 정의 구조 태그를 만날 것입니다 ...
