網站首頁 編程語言 正文
命令行參數處理以及urfave/cli使用
1.通過Os.Args獲取cli的參數
package main import ( "fmt" "os" ) func main() { if(len(os.Args) > 1) { for _,value := range os.Args{ fmt.Printf( "%v\n",value) } return } fmt.Printf( "%s","沒輸入參數") }
2. 增加命令行選項
我們經常能看到 使用一些命令行會有很多選項。例如 ls -l 等
可以使用flag包來獲取選項,例如下面的代碼:
package main import ( "flag" "fmt" ) var recusive bool var test string var level int func init() { flag.BoolVar(&recusive, "r", false, "Recusive xxxx") flag.StringVar(&test, "t", "Default String", "string option") flag.IntVar(&level, "l", 1, "level of xxxx") flag.Parse() } func main() { fmt.Println("recusive:", recusive) fmt.Println("test:", test) fmt.Println("level:", level) }
init函數內部使用了flag包中的BoolVar、StringVar以及IntVar等方法,標記了命令的選項。
// StringVar defines a string flag with specified name, default value, and usage string. // The argument p points to a string variable in which to store the value of the flag. func StringVar(p *string, name string, value string, usage string) { CommandLine.Var(newStringValue(value, p), name, usage) }
像源碼中描述那樣,第一個參數用來接收輸入的參數值,第二個用來定義參數名稱(-l -r 等),第三個是默認參數、第四個是使用方法。
于是像上面的代碼我們就可以這樣使用:這里BoolVar的默認值是false, -r后面不增加其他參數,不用 -r true 這樣。
3.urfave/cli的簡單使用
urfave/cli是一個命令行的框架。舉例說明:
package main import ( "fmt" "os" "github.com/urfave/cli" //必須使用這個包 ) func main() { //定義兩個變量用于接收控制臺輸入的值 var stringValue string var boolValue bool //new一個app出來,就是我們的命令行程序 app := cli.NewApp() app.Name = "TestCliApp" //起個名稱 app.Usage = "Test" //描述一下用途 app.Version = "2.0.0" //設置一下版本號 //重點可以設置一些選項操作 //第一個是一個字符串的選項,第二個是一個布爾的選項 app.Flags = []cli.Flag{ cli.StringFlag{ Name: "StringOption,s", Value: "DefaultValue", Usage: "Display a string value", Destination: &stringValue, }, cli.BoolFlag{ Name: "BoolOption,b", Usage: "Display a bool value", Destination: &boolValue, }, } //定義我們命令行程序主要的工作 app.Action = func(c *cli.Context) error { if c.NArg() > 0 { cmds := c.Args() for index, v := range cmds { fmt.Printf("args[%d]=%v\t", index, v) } } else { fmt.Println("No Args") } fmt.Println("stringOption", stringValue) fmt.Println("boolOption", boolValue) return nil } //執行程序 app.Run(os.Args) }
有幾個點:
- 1.定義Flag的時候,Name可以用【,】分割,前面長的 可以用 --XXXX 來增加參數,后面則是短名 -x 來表示
- 2.默認會有help和version兩個選項
- 3.我在使用的時候發現,當輸入正常的 -b -s Hello 這樣的選項的時候,C.NArg()返回的值是0,而輸出錯誤的參數列表的時候,則是有值存在的。
我們可以用 -h (--help)查看一下生成的文檔
可以參考具體的文檔來構建自己的命令
原文鏈接:https://www.cnblogs.com/dcz2015/p/11212611.html
相關推薦
- 2022-05-28 使用Docker部署ASP.NET?Core程序_基礎應用
- 2022-08-29 C#中Attribute特性的用法_C#教程
- 2022-06-13 Openstack各組件邏輯關系及運行流程解析_OpenStack
- 2023-10-24 ElementUI日期選擇器DatePicker限制所選時間范圍(例如限制前后時長不超一個月)的實現
- 2022-09-19 正則表達式regexp_replace的使用方法_正則表達式
- 2022-03-12 使用xshell連接linux服務器_Linux
- 2022-10-08 Pandas數據分析-pandas數據框的多層索引_python
- 2022-08-16 .Net使用Xunit工具進行單元測試_實用技巧
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支