這篇文章為大家帶來有關GO命令行的詳細介紹。大部分命令行知識點都是大家經常用到的,為此分享給大家做個參考。一起跟隨小編過來看看吧。
創新互聯公司-專業網站定制、快速模板網站建設、高性價比掇刀網站開發、企業建站全套包干低至880元,成熟完善的模板庫,直接使用。一站式掇刀網站制作公司更省心,省錢,快速模板網站建設找我們,業務覆蓋掇刀地區。費用合理售后完善,十載實體公司更值得信賴。? 一. os.Args
? 二. flag
? 三. 結合os.Args與flag實現子命令
? 附. 參考文檔
os.Args用于獲取通過命令行傳入的參數
?os.Args[0]:程序執行路徑
?os.Args[1]:第1個參數
?os.Args[2]:第2個參數
?len(os.Args):參數數量
示例如下
package main
import (
"fmt"
"os"
)
func main() {
fmt.Println("Program:", os.Args[0])
for i, v := range os.Args[1:] {
fmt.Printf("Arg[%d]: %v\n", i, v)
}
}
測試效果
# 編譯執行
go build arg.go
./arg foo "hello world" bar
# 輸出
Program: ./arg
Arg[0]: foo
Arg[1]: hello world
Arg[2]: bar
golang內置的flag模塊可以實現命令行flag解析。
什么是flag,舉例說明(加粗部分就是flag):
? wc-l
? ./configure--prefix=/usr/local/nginx
示例如下(摘取自gobyexample)
package main
import (
"flag"
"fmt"
)
func main() {
// flag.String返回的是指針
// word表示參數名,foo表示默認值,a string表示參數釋義(在-h或解析異常時候會看到)
// flag.Int、flag.Bool與flag.String同理,不再贅述
wordPtr := flag.String("word", "foo", "a string")
numbPtr := flag.Int("numb", 42, "an int")
boolPtr := flag.Bool("fork", false, "a bool")
// flag.StringVar返回的是非指針
var svar string
flag.StringVar(&svar, "svar", "bar", "a string var")
// 進行flag解析
flag.Parse()
fmt.Println("word:", *wordPtr)
fmt.Println("numb:", *numbPtr)
fmt.Println("fork:", *boolPtr)
fmt.Println("svar:", svar)
fmt.Println("tail:", flag.Args())
}
測試效果
# 編譯
go build flag.go
./flag -word=opt -numb=7 -fork -svar=flag
# 輸出
word: opt
numb: 7
fork: true
svar: flag
tail: []
./flag -word=opt
# 輸出
word: opt
numb: 42
fork: false
svar: bar
tail: []
./flag -word=opt a1 a2 a3
# 輸出
word: opt
numb: 42
fork: false
svar: bar
tail: [a1 a2 a3]
./flag -word=opt a1 a2 a3 -numb=7
# 輸出
word: opt
numb: 42
fork: false
svar: bar
tail: [a1 a2 a3 -numb=7]
./flag -h
# 輸出
Usage of ./flag:
-fork
a bool
-numb int
an int (default 42)
-svar string
a string var (default "bar")
-word string
a string (default "foo")
./flag -wat
# 輸出
flag provided but not defined: -wat
Usage of ./flag:
...
該例子,在測試時候只使用了“單橫線+參數名”,實際有4種方式,效果是相同的
-word opt
-word=opt
--word opt
--word=opt
如果想實現子命令效果,例如:
? docker ps --last 10
? docker images --help
這需要將os.Args和flag結合使用。基本原理:創建多個flag集合(即*flag.FlagSet),每個flag集合對應不同的os.Args
示例如下(摘取自gobyexample)
package main
import (
"flag"
"fmt"
"os"
)
func main() {
fooCmd := flag.NewFlagSet("foo", flag.ExitOnError)
fooEnable := fooCmd.Bool("enable", false, "enable")
fooName := fooCmd.String("name", "", "name")
barCmd := flag.NewFlagSet("bar", flag.ExitOnError)
barLevel := barCmd.Int("level", 0, "level")
if len(os.Args) < 2 {
fmt.Println("expected 'foo' or 'bar' subcommands")
os.Exit(1)
}
switch os.Args[1] {
case "foo":
fooCmd.Parse(os.Args[2:])
fmt.Println("subcommand 'foo'")
fmt.Println(" enable:", *fooEnable)
fmt.Println(" name:", *fooName)
fmt.Println(" tail:", fooCmd.Args())
case "bar":
barCmd.Parse(os.Args[2:])
fmt.Println("subcommand 'bar'")
fmt.Println(" level:", *barLevel)
fmt.Println(" tail:", barCmd.Args())
default:
fmt.Println("expected 'foo' or 'bar' subcommands")
os.Exit(1)
}
}
測試效果
# 編譯
go build subflag.go
./subflag foo -enable -name=joe a1 a2
# 輸出
subcommand 'foo'
enable: true
name: joe
tail: [a1 a2]
./subflag bar -level 8 a1
# 輸出
subcommand 'bar'
level: 8
tail: [a1]
./subflag bar -enable a1
# 輸出
flag provided but not defined: -enable
Usage of bar:
-level int
level
以上就是GO命令行的詳細內容了,看完之后是否有所收獲呢?如果想了解更多相關內容,歡迎關注創新互聯網站制作公司行業資訊,感謝各位的閱讀!創新互聯www.cdcxhl.cn,專業提供香港、美國云服務器,動態BGP最優骨干路由自動選擇,持續穩定高效的網絡助力業務部署。公司持有工信部辦法的idc、isp許可證, 機房獨有T級流量清洗系統配攻擊溯源,準確進行流量調度,確保服務器高可用性。佳節活動現已開啟,新人活動云服務器買多久送多久。
分享標題:GO命令行詳細價紹-創新互聯
標題網址:http://m.newbst.com/article32/cosesc.html
成都網站建設公司_創新互聯,為您提供搜索引擎優化、微信小程序、服務器托管、面包屑導航、定制開發、微信公眾號
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯