cobra
Cobraに関する深い知識を持ち、サブコマンドやフラグ、引数検証、シェル補完、ヘルプ生成など、現代的なCLIアプリケーション開発に必要な機能を活用して、開発者がコマンドラインツールを効率的に構築できるよう支援するSkill。
📜 元の英語説明(参考)
You are an expert in Cobra, the most popular Go library for building modern CLI applications. You help developers create command-line tools with subcommands, flags, argument validation, shell completions, and help generation — powering CLIs like kubectl, Hugo, GitHub CLI, and Docker.
🇯🇵 日本人クリエイター向け解説
Cobraに関する深い知識を持ち、サブコマンドやフラグ、引数検証、シェル補完、ヘルプ生成など、現代的なCLIアプリケーション開発に必要な機能を活用して、開発者がコマンドラインツールを効率的に構築できるよう支援するSkill。
※ jpskill.com 編集部が日本のビジネス現場向けに補足した解説です。Skill本体の挙動とは独立した参考情報です。
下記のコマンドをコピーしてターミナル(Mac/Linux)または PowerShell(Windows)に貼り付けてください。 ダウンロード → 解凍 → 配置まで全自動。
mkdir -p ~/.claude/skills && cd ~/.claude/skills && curl -L -o cobra.zip https://jpskill.com/download/14761.zip && unzip -o cobra.zip && rm cobra.zip
$d = "$env:USERPROFILE\.claude\skills"; ni -Force -ItemType Directory $d | Out-Null; iwr https://jpskill.com/download/14761.zip -OutFile "$d\cobra.zip"; Expand-Archive "$d\cobra.zip" -DestinationPath $d -Force; ri "$d\cobra.zip"
完了後、Claude Code を再起動 → 普通に「動画プロンプト作って」のように話しかけるだけで自動発動します。
💾 手動でダウンロードしたい(コマンドが難しい人向け)
- 1. 下の青いボタンを押して
cobra.zipをダウンロード - 2. ZIPファイルをダブルクリックで解凍 →
cobraフォルダができる - 3. そのフォルダを
C:\Users\あなたの名前\.claude\skills\(Win)または~/.claude/skills/(Mac)へ移動 - 4. Claude Code を再起動
⚠️ ダウンロード・利用は自己責任でお願いします。当サイトは内容・動作・安全性について責任を負いません。
🎯 このSkillでできること
下記の説明文を読むと、このSkillがあなたに何をしてくれるかが分かります。Claudeにこの分野の依頼をすると、自動で発動します。
📦 インストール方法 (3ステップ)
- 1. 上の「ダウンロード」ボタンを押して .skill ファイルを取得
- 2. ファイル名の拡張子を .skill から .zip に変えて展開(macは自動展開可)
- 3. 展開してできたフォルダを、ホームフォルダの
.claude/skills/に置く- · macOS / Linux:
~/.claude/skills/ - · Windows:
%USERPROFILE%\.claude\skills\
- · macOS / Linux:
Claude Code を再起動すれば完了。「このSkillを使って…」と話しかけなくても、関連する依頼で自動的に呼び出されます。
詳しい使い方ガイドを見る →- 最終更新
- 2026-05-18
- 取得日時
- 2026-05-18
- 同梱ファイル
- 1
📖 Skill本文(日本語訳)
※ 原文(英語/中国語)を Gemini で日本語化したものです。Claude 自身は原文を読みます。誤訳がある場合は原文をご確認ください。
Cobra — Go CLI フレームワーク
Cobra は、最新の CLI アプリケーションを構築するための最も人気のある Go ライブラリです。あなたは Cobra のエキスパートです。開発者がサブコマンド、フラグ、引数検証、シェル補完、ヘルプ生成を備えたコマンドラインツールを作成するのを支援し、kubectl、Hugo、GitHub CLI、Docker などの CLI を強化します。
主要な機能
アプリケーション構造
// cmd/root.go — ルートコマンド
package cmd
import (
"fmt"
"os"
"github.com/spf13/cobra"
"github.com/spf13/viper"
)
var cfgFile string
var verbose bool
var rootCmd = &cobra.Command{
Use: "myctl",
Short: "My CLI tool for managing stuff",
Long: `A comprehensive CLI tool for managing deployments, configs, and services.`,
PersistentPreRun: func(cmd *cobra.Command, args []string) {
if verbose {
fmt.Println("Verbose mode enabled")
}
},
}
func Execute() {
if err := rootCmd.Execute(); err != nil {
os.Exit(1)
}
}
func init() {
cobra.OnInitialize(initConfig)
rootCmd.PersistentFlags().StringVar(&cfgFile, "config", "", "config file (default $HOME/.myctl.yaml)")
rootCmd.PersistentFlags().BoolVarP(&verbose, "verbose", "v", false, "verbose output")
}
func initConfig() {
if cfgFile != "" {
viper.SetConfigFile(cfgFile)
} else {
home, _ := os.UserHomeDir()
viper.AddConfigPath(home)
viper.SetConfigName(".myctl")
}
viper.AutomaticEnv()
viper.ReadInConfig()
}
// cmd/deploy.go — フラグ付きのサブコマンド
package cmd
import (
"fmt"
"github.com/spf13/cobra"
)
var deployCmd = &cobra.Command{
Use: "deploy [service]",
Short: "Deploy a service to the target environment",
Long: `Deploy a service to the specified environment with optional version override.`,
Args: cobra.ExactArgs(1), // Require exactly 1 argument
Example: ` myctl deploy api --env production --version v2.1.0
myctl deploy worker --env staging --dry-run`,
RunE: func(cmd *cobra.Command, args []string) error {
service := args[0]
env, _ := cmd.Flags().GetString("env")
version, _ := cmd.Flags().GetString("version")
dryRun, _ := cmd.Flags().GetBool("dry-run")
if dryRun {
fmt.Printf("DRY RUN: Would deploy %s@%s to %s\n", service, version, env)
return nil
}
fmt.Printf("Deploying %s@%s to %s...\n", service, version, env)
return performDeploy(service, env, version)
},
}
func init() {
rootCmd.AddCommand(deployCmd)
deployCmd.Flags().StringP("env", "e", "staging", "target environment")
deployCmd.Flags().String("version", "latest", "version to deploy")
deployCmd.Flags().Bool("dry-run", false, "simulate deployment")
deployCmd.MarkFlagRequired("env")
}
// cmd/status.go — 別のサブコマンド
var statusCmd = &cobra.Command{
Use: "status [service]",
Short: "Show service status",
Aliases: []string{"st"}, // myctl st == myctl status
Args: cobra.MaximumNArgs(1),
ValidArgsFunction: func(cmd *cobra.Command, args []string, toComplete string) ([]string, cobra.ShellCompDirective) {
// Dynamic completion: list available services
services := []string{"api", "worker", "scheduler", "web"}
return services, cobra.ShellCompDirectiveNoFileComp
},
RunE: func(cmd *cobra.Command, args []string) error {
if len(args) == 0 {
return showAllStatus()
}
return showServiceStatus(args[0])
},
}
シェル補完
# 補完の生成
myctl completion bash > /etc/bash_completion.d/myctl
myctl completion zsh > "${fpath[1]}/_myctl"
myctl completion fish > ~/.config/fish/completions/myctl.fish
# Cobra はすべてのコマンド、フラグ、引数の補完を自動的に生成します
インストール
go get github.com/spf13/cobra
# スキャフォールディングツール
go install github.com/spf13/cobra-cli@latest
cobra-cli init
cobra-cli add deploy
cobra-cli add status
ベストプラクティス
- 組織化のためのサブコマンド — 関連する機能をグループ化します:
myctl deploy、myctl status、myctl config - Viper を使用したフラグ — フラグを Viper にバインドして、統一された設定 (CLI フラグ + 環境変数 + 設定ファイル) を実現します
- Run よりも RunE —
Runの代わりにRunE(エラーを返します) を使用します。Cobra がエラー表示と終了コードを処理します - 引数の検証 —
Args: cobra.ExactArgs(1)またはカスタムバリデーターを使用します。実行前にエラーをキャッチします - シェル補完 — Cobra は bash/zsh/fish/powershell の補完を生成します。動的な補完のために
ValidArgsFunctionを追加します - ヘルプは自動 — Cobra は
--help、使用方法テキスト、およびサブコマンドリストを生成します。LongおよびExampleでカスタマイズします - 利便性のためのエイリアス — 短いエイリアスを追加します:
statusの場合はst、deployの場合はd - 永続的なフラグ — すべてのサブコマンドに適用されるフラグ (
--verbose、--config) については、ルートでPersistentFlags()を使用します
📜 原文 SKILL.md(Claudeが読む英語/中国語)を展開
Cobra — Go CLI Framework
You are an expert in Cobra, the most popular Go library for building modern CLI applications. You help developers create command-line tools with subcommands, flags, argument validation, shell completions, and help generation — powering CLIs like kubectl, Hugo, GitHub CLI, and Docker.
Core Capabilities
Application Structure
// cmd/root.go — Root command
package cmd
import (
"fmt"
"os"
"github.com/spf13/cobra"
"github.com/spf13/viper"
)
var cfgFile string
var verbose bool
var rootCmd = &cobra.Command{
Use: "myctl",
Short: "My CLI tool for managing stuff",
Long: `A comprehensive CLI tool for managing deployments, configs, and services.`,
PersistentPreRun: func(cmd *cobra.Command, args []string) {
if verbose {
fmt.Println("Verbose mode enabled")
}
},
}
func Execute() {
if err := rootCmd.Execute(); err != nil {
os.Exit(1)
}
}
func init() {
cobra.OnInitialize(initConfig)
rootCmd.PersistentFlags().StringVar(&cfgFile, "config", "", "config file (default $HOME/.myctl.yaml)")
rootCmd.PersistentFlags().BoolVarP(&verbose, "verbose", "v", false, "verbose output")
}
func initConfig() {
if cfgFile != "" {
viper.SetConfigFile(cfgFile)
} else {
home, _ := os.UserHomeDir()
viper.AddConfigPath(home)
viper.SetConfigName(".myctl")
}
viper.AutomaticEnv()
viper.ReadInConfig()
}
// cmd/deploy.go — Subcommand with flags
package cmd
import (
"fmt"
"github.com/spf13/cobra"
)
var deployCmd = &cobra.Command{
Use: "deploy [service]",
Short: "Deploy a service to the target environment",
Long: `Deploy a service to the specified environment with optional version override.`,
Args: cobra.ExactArgs(1), // Require exactly 1 argument
Example: ` myctl deploy api --env production --version v2.1.0
myctl deploy worker --env staging --dry-run`,
RunE: func(cmd *cobra.Command, args []string) error {
service := args[0]
env, _ := cmd.Flags().GetString("env")
version, _ := cmd.Flags().GetString("version")
dryRun, _ := cmd.Flags().GetBool("dry-run")
if dryRun {
fmt.Printf("DRY RUN: Would deploy %s@%s to %s\n", service, version, env)
return nil
}
fmt.Printf("Deploying %s@%s to %s...\n", service, version, env)
return performDeploy(service, env, version)
},
}
func init() {
rootCmd.AddCommand(deployCmd)
deployCmd.Flags().StringP("env", "e", "staging", "target environment")
deployCmd.Flags().String("version", "latest", "version to deploy")
deployCmd.Flags().Bool("dry-run", false, "simulate deployment")
deployCmd.MarkFlagRequired("env")
}
// cmd/status.go — Another subcommand
var statusCmd = &cobra.Command{
Use: "status [service]",
Short: "Show service status",
Aliases: []string{"st"}, // myctl st == myctl status
Args: cobra.MaximumNArgs(1),
ValidArgsFunction: func(cmd *cobra.Command, args []string, toComplete string) ([]string, cobra.ShellCompDirective) {
// Dynamic completion: list available services
services := []string{"api", "worker", "scheduler", "web"}
return services, cobra.ShellCompDirectiveNoFileComp
},
RunE: func(cmd *cobra.Command, args []string) error {
if len(args) == 0 {
return showAllStatus()
}
return showServiceStatus(args[0])
},
}
Shell Completions
# Generate completions
myctl completion bash > /etc/bash_completion.d/myctl
myctl completion zsh > "${fpath[1]}/_myctl"
myctl completion fish > ~/.config/fish/completions/myctl.fish
# Cobra generates completions for all commands, flags, and arguments automatically
Installation
go get github.com/spf13/cobra
# Scaffolding tool
go install github.com/spf13/cobra-cli@latest
cobra-cli init
cobra-cli add deploy
cobra-cli add status
Best Practices
- Subcommands for organization — Group related functionality:
myctl deploy,myctl status,myctl config - Flags with Viper — Bind flags to Viper for unified config (CLI flags + env vars + config file)
- RunE over Run — Use
RunE(returns error) instead ofRun; Cobra handles error display and exit codes - Argument validation — Use
Args: cobra.ExactArgs(1)or custom validators; catch errors before execution - Shell completions — Cobra generates bash/zsh/fish/powershell completions; add
ValidArgsFunctionfor dynamic completion - Help is automatic — Cobra generates
--help, usage text, and subcommand lists; customize withLongandExample - Aliases for convenience — Add short aliases:
stforstatus,dfordeploy - Persistent flags — Use
PersistentFlags()on root for flags that apply to all subcommands (--verbose,--config)