婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > Golang中基礎(chǔ)的命令行模塊urfave/cli的用法說明

Golang中基礎(chǔ)的命令行模塊urfave/cli的用法說明

熱門標簽:杭州人工智能電銷機器人費用 江蘇呼叫中心外呼系統(tǒng)有效果嗎 貴州電話智能外呼系統(tǒng) 地圖區(qū)域圖標注后導出 利用地圖標注位置 官渡電銷外呼管理系統(tǒng)怎么收費 赤峰電銷 谷歌美發(fā)店地圖標注 400開頭電話怎樣申請

前言

相信只要部署過線上服務(wù),都知道啟動參數(shù)一定是必不可少的,當你在不同的網(wǎng)絡(luò)、硬件、軟件環(huán)境下去啟動一個服務(wù)的時候,總會有一些啟動參數(shù)是不確定的,這時候就需要通過命令行模塊去解析這些參數(shù),urfave/cli是Golang中一個簡單實用的命令行工具。

安裝

通過 go get github.com/urfave/cli 命令即可完成安裝。

正文

使用了urfave/cli之后,你的程序就會變成一個命令行程序,以下就是通過urfave/cli創(chuàng)建的一個最簡單的命令行程序,它設(shè)定了一些基礎(chǔ)的信息,這個程序的最終只是簡單的打印了Test信息。

package main 
import (
 "github.com/urfave/cli"
 "os"
 "log"
 "fmt"
)
 
func main() {
 //實例化一個命令行程序
 oApp := cli.NewApp()
 //程序名稱
 oApp.Name = "GoTool"
 //程序的用途描述
 oApp.Usage = "To save the world"
 //程序的版本號
 oApp.Version = "1.0.0"
 //該程序執(zhí)行的代碼
 oApp.Action = func(c *cli.Context) error {
 fmt.Println("Test")
 return nil
 }
 //啟動
 if err := oApp.Run(os.Args); err != nil {
 log.Fatal(err)
 }
 /*
 result:
 [root@localhost cli]# go run main.go help
 
 NAME:
 GoTool - To save the world
 
 USAGE:
 main [global options] command [command options] [arguments...]
 
 VERSION:
 1.0.0
 
 COMMANDS:
 help, h Shows a list of commands or help for one command
 
 GLOBAL OPTIONS:
 --help, -h  show help
 --version, -v print the version
 
 [root@localhost cli]# go run main.go 
 Test
 */ 
}

我們看到運行 go run main.go help 之后會輸出一些幫助信息,說明你的程序已經(jīng)成功成為一個命令行程序,接著使用命令 go run main.go 運行這個程序,結(jié)果是打印了Test信息,所以這個程序?qū)嶋H運行的函數(shù)由oApp.Action來控制,你后面的代碼應該都在這個函數(shù)的內(nèi)部去實現(xiàn)。

接下來我們設(shè)定一些常見的啟動參數(shù),非常的簡單,代碼如下

package main 
import (
 "github.com/urfave/cli"
 "os"
 "log"
 "fmt"
)
 
func main() {
 //實例化一個命令行程序
 oApp := cli.NewApp()
 //程序名稱
 oApp.Name = "GoTool"
 //程序的用途描述
 oApp.Usage = "To save the world"
 //程序的版本號
 oApp.Version = "1.0.0"
 
 //預置變量
 var host string
 var debug bool
 
 //設(shè)置啟動參數(shù)
 oApp.Flags = []cli.Flag{
 //參數(shù)類型string,int,bool
 cli.StringFlag{
 Name:  "host",   //參數(shù)名字
 Value:  "127.0.0.1",  //參數(shù)默認值
 Usage:  "Server Address", //參數(shù)功能描述
 Destination: host,   //接收值的變量
 },
 cli.IntFlag{
 Name:  "port,p",
 Value:  8888,
 Usage:  "Server port",
 },
 cli.BoolFlag{
 Name:  "debug",
 Usage:  "debug mode",
 Destination: debug,
 },
 }
 
 //該程序執(zhí)行的代碼
 oApp.Action = func(c *cli.Context) error {
 fmt.Printf("host=%v \n",host)
 fmt.Printf("host=%v \n",c.Int("port")) //不使用變量接收,直接解析
 fmt.Printf("host=%v \n",debug)
 /*
 result:
 [root@localhost cli]# go run main.go --port 7777
 host=127.0.0.1 
 host=7777 
 host=false 
 
 [root@localhost cli]# go run main.go help
 NAME:
  GoTool - To save the world
 
 USAGE:
  main [global options] command [command options] [arguments...]
 
 VERSION:
  1.0.0
 
 COMMANDS:
 help, h Shows a list of commands or help for one command
 
 GLOBAL OPTIONS:
  --host value   Server Address (default: "127.0.0.1")
  --port value, -p value Server port (default: 8888)
  --debug     debug mode
  --help, -h    show help
  --version, -v   print the version
 */
 return nil
 }
 //啟動
 if err := oApp.Run(os.Args); err != nil {
 log.Fatal(err)
 } 
}

執(zhí)行 go run main.go --port 7777 之后,可以看到輸出了設(shè)定的7777端口而非默認的8888端口,而服務(wù)器地址(host)和調(diào)試模式(debug)都輸出了默認的數(shù)值。

如果第三方人員第一次使用你的程序也可以通過help命令看到可以設(shè)定的參數(shù)都有哪些,非常的人性化。

當然,urfave/cli還允許我們設(shè)置多個命令,不同的命令執(zhí)行不同的操作,具體如下

package main 
import (
 "github.com/urfave/cli"
 "os"
 "log"
 "fmt"
)
 
func main() {
 //實例化一個命令行程序
 oApp := cli.NewApp()
 //程序名稱
 oApp.Name = "GoTool"
 //程序的用途描述
 oApp.Usage = "To save the world"
 //程序的版本號
 oApp.Version = "1.0.0"
 
 //設(shè)置多個命令處理函數(shù)
 oApp.Commands = []cli.Command{
 {
 //命令全稱
 Name:"lang",
 //命令簡寫
 Aliases:[]string{"l"},
 //命令詳細描述
 Usage:"Setting language",
 //命令處理函數(shù)
 Action: func(c *cli.Context) {
 // 通過c.Args().First()獲取命令行參數(shù)
 fmt.Printf("language=%v \n",c.Args().First())
 },
 },
 {
 Name:"encode",
 Aliases:[]string{"e"},
 Usage:"Setting encoding",
 Action: func(c *cli.Context) {
 fmt.Printf("encoding=%v \n",c.Args().First())
 },
 },
 }
 
 //啟動
 if err := oApp.Run(os.Args); err != nil {
 log.Fatal(err)
 }
 
 /*
 [root@localhost cli]# go run main.go l english
 language=english 
 
 [root@localhost cli]# go run main.go e utf8
 encoding=utf8 
 
 [root@localhost cli]# go run main.go help
 NAME:
 GoTool - To save the world
 
 USAGE:
 main [global options] command [command options] [arguments...]
 
 VERSION:
 1.0.0
 
 COMMANDS:
 lang, l Setting language
 encode, e Setting encoding
 help, h Shows a list of commands or help for one command
 
 GLOBAL OPTIONS:
 --help, -h  show help
 --version, -v print the version
 */ 
}

上面代碼只實現(xiàn)了兩個簡單命令,兩個命令最后的處理函數(shù)不同,自然使用不同命令,最后的輸出也不一樣。

補充:Go語言命令行庫-urfave/cli(gopkg.in/urfave/cli.v2)

Go語言命令行庫-urfave/cli

官網(wǎng):https://github.com/urfave/cli

很多用Go寫的命令行程序都用了urfave/cli這個庫。urfave/cli是一個命令行的框架。

用C寫過命令行程序的人應該都不陌生,我們需要根據(jù)argc/argv一個個地解析命令行參數(shù),調(diào)用不同的函數(shù),最后還要寫一個usage()函數(shù)用于打印幫助信息。urfave/cli把這個過程做了一下封裝,抽象出flag/command/subcommand這些模塊,用戶只需要提供一些模塊的配置,參數(shù)的解析和關(guān)聯(lián)在庫內(nèi)部完成,幫助信息也可以自動生成。

總體來說,urfave/cli這個庫還是很好用的,完成了很多routine的工作,程序員只需要專注于具體業(yè)務(wù)邏輯的實現(xiàn)。

怎么使用urfave/cli

go如何編寫命令行(cli)程序

首先下載類庫包

go get github.com/urfave/cli

main.go

package main
import (
 "os"
 "github.com/urfave/cli/v2"
 "fmt"
)
func main() {
 app := cli.App{
 Name: "greet",
 Usage: "say a greeting",
 Action: func(c *cli.Context) error {
 fmt.Println("Greetings")
 return nil
 },
 }
 // 接受os.Args啟動程序
 app.Run(os.Args)
}

Flags 用于設(shè)置參數(shù)。

Action 對應的函數(shù)就是你具體對各個參數(shù)具體的處理邏輯。

“gopkg.in/urfave/cli.v2” 和 “github.com/urfave/cli”

官網(wǎng):https://github.com/urfave/cli

gopkg:一種方便的go pakcage管理方式

根據(jù)官網(wǎng) readme描述,現(xiàn)在2個版本,主版本使用的是 v2 分支。

導入包為: “github.com/urfave/cli/v2”

有些 go 的代碼庫地址是gopkg.in開頭的,比如gopkg.in/urfave/cli.v2。

v2 表明版本號為 v2,而代碼則為 github 上面相應的 v2 branch。

這個也是 Go 的包管理解決方案之一,就是 gopkg.in 做了一個轉(zhuǎn)發(fā)過程,實際上是使用了 github 里面的相應的 tag 的代碼

子命令 Subcommands

如下 demo所示,我們再Action:同層添加 我們定義指針 cli.Command 變量即可。

demo:

var daemonStopCmd = cli.Command{
 Name: "stop",
 Usage: "Stop a running lotus daemon",
 Flags: []cli.Flag{},
 Action: func(cctx *cli.Context) error {
 panic("wombat attack")
 },
}
func main() {
 app := cli.App{
 Name: "greet",
 Usage: "say a greeting",
 Action: func(c *cli.Context) error {
 fmt.Println("Greetings")
 return nil
 },
 Subcommands: []*cli.Command{
 daemonStopCmd,
 },
 }
 // 接受os.Args啟動程序
 app.Run(os.Args)
}

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。

您可能感興趣的文章:
  • golang執(zhí)行命令操作 exec.Command
  • golang執(zhí)行命令獲取執(zhí)行結(jié)果狀態(tài)(推薦)
  • Golang命令行進行debug調(diào)試操作
  • golang中命令行庫cobra的使用方法示例
  • 利用Golang如何調(diào)用Linux命令詳解
  • Golang匯編命令解讀及使用

標簽:保定 宜春 黔西 泰安 河池 武漢 松原 鷹潭

巨人網(wǎng)絡(luò)通訊聲明:本文標題《Golang中基礎(chǔ)的命令行模塊urfave/cli的用法說明》,本文關(guān)鍵詞  Golang,中,基礎(chǔ),的,命令行,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Golang中基礎(chǔ)的命令行模塊urfave/cli的用法說明》相關(guān)的同類信息!
  • 本頁收集關(guān)于Golang中基礎(chǔ)的命令行模塊urfave/cli的用法說明的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    久久99精品国产.久久久久久| 美女诱惑一区二区| 欧美日韩mp4| 成人午夜伦理影院| 亚洲国产综合视频在线观看| 国产精品福利一区二区三区| 久久久久9999亚洲精品| 欧美一区二区女人| 51精品国自产在线| 欧美午夜精品久久久| 一本色道久久综合亚洲91 | 国产精品美女视频| 欧美最猛性xxxxx直播| 国产精品69久久久久水密桃| 精品国产污网站| 欧美精品九九99久久| 日韩欧美一区二区不卡| 日韩精品一区二区三区在线观看| 欧美日本在线一区| voyeur盗摄精品| 不卡av电影在线播放| 福利91精品一区二区三区| 国产在线看一区| 床上的激情91.| 99久久精品国产精品久久| 懂色中文一区二区在线播放| 国产精品白丝jk黑袜喷水| 丁香天五香天堂综合| 高清不卡一区二区| 色综合欧美在线视频区| 色婷婷av一区二区| 91麻豆精品国产91久久久久久 | 天天色天天操综合| 亚洲 欧美综合在线网络| 免费久久99精品国产| 免费久久99精品国产| 成人综合日日夜夜| 欧美在线不卡一区| 精品国偷自产国产一区| 88在线观看91蜜桃国自产| 久久噜噜亚洲综合| 亚洲精品免费在线观看| 亚洲第一二三四区| 久久精品国产77777蜜臀| 成人黄动漫网站免费app| 精品视频色一区| 久久嫩草精品久久久久| 亚洲精品国产无天堂网2021| 美女精品一区二区| 粉嫩av一区二区三区在线播放| 91网站最新地址| 日韩欧美中文字幕一区| 中文字幕一区不卡| 免费亚洲电影在线| 日本韩国一区二区三区视频| 日韩精品最新网址| 国产精品久久久爽爽爽麻豆色哟哟| 亚洲成人福利片| 国产99久久久久| 日韩视频中午一区| 欧美激情一区在线观看| 久久精品国产99国产| 色噜噜狠狠成人网p站| 国产日韩欧美不卡在线| 免费欧美日韩国产三级电影| 亚洲成人动漫在线免费观看| gogogo免费视频观看亚洲一| 欧美亚洲一区三区| 久久精品理论片| 国产色综合久久| 免费一级片91| 中文字幕一区二区三区蜜月 | 亚洲欧美综合在线精品| 欧美三级韩国三级日本一级| 337p亚洲精品色噜噜噜| 亚洲欧洲日韩在线| 美腿丝袜在线亚洲一区| 9191精品国产综合久久久久久| 亚洲国产高清不卡| 国产精品一区二区果冻传媒| 日韩一区二区三区在线观看| 亚洲成人av一区二区三区| 欧美在线视频全部完| 亚洲欧美一区二区不卡| 99国产精品久久久久久久久久| 国产亚洲视频系列| 国产精品一二一区| 欧美激情艳妇裸体舞| 蜜桃视频一区二区三区| 这里只有精品视频在线观看| 亚洲成人免费在线观看| 欧美性色黄大片手机版| 亚洲电影一级黄| 欧美高清视频www夜色资源网| 亚洲午夜久久久久久久久久久| 色网综合在线观看| 亚洲色图视频免费播放| www.在线成人| 亚洲另类春色校园小说| 欧美在线视频不卡| 免费欧美在线视频| 欧美精品一区二区三区在线| 国产精品一卡二卡在线观看| 国产视频一区二区在线| 成人精品免费视频| 中文字幕综合网| 欧美日韩在线综合| 青青草原综合久久大伊人精品| 26uuu另类欧美| 国产九九视频一区二区三区| 国产精品乱人伦| 色老汉av一区二区三区| 日本在线观看不卡视频| 国产日产欧美一区| 国产精品亚洲综合一区在线观看| 国产欧美日韩中文久久| 日本韩国欧美国产| 久久av老司机精品网站导航| 国产色综合一区| 国产精品一区二区无线| 一区二区在线观看视频在线观看| 91 com成人网| 成人aaaa免费全部观看| 日韩精品一级中文字幕精品视频免费观看 | 欧美性猛片xxxx免费看久爱 | 欧美日韩一级黄| 亚洲日本成人在线观看| 懂色av一区二区三区免费看| 久久色在线视频| 懂色av中文一区二区三区| 成人免费在线视频| 欧美一区二区国产| 肉色丝袜一区二区| 一区二区三区成人| 国产精品美女www爽爽爽| 欧美变态口味重另类| 欧美一区二区三区电影| 欧美色大人视频| 色婷婷综合激情| 91免费看`日韩一区二区| 成人午夜电影网站| 国产福利一区二区三区| 国产精品伊人色| 国产精品一二三在| 国产伦精品一区二区三区免费| 蜜臀久久99精品久久久久久9| 无码av免费一区二区三区试看| 一区二区三区不卡视频在线观看| 亚洲欧美aⅴ...| 亚洲激情成人在线| 亚洲一区二区影院| 一个色在线综合| 亚洲午夜视频在线| 天使萌一区二区三区免费观看| 亚洲成人久久影院| 日韩在线观看一区二区| 免费成人结看片| 激情都市一区二区| 国产最新精品精品你懂的| 国产一区在线不卡| 国产成人鲁色资源国产91色综| 国产.欧美.日韩| 色偷偷久久一区二区三区| 欧美调教femdomvk| 日韩一区二区三区在线| 国产亚洲欧美日韩俺去了| 国产精品午夜春色av| 亚洲欧洲日韩一区二区三区| 亚洲九九爱视频| 日产国产高清一区二区三区| 国内精品久久久久影院薰衣草| 国产高清不卡二三区| 91麻豆精东视频| 在线综合视频播放| 久久亚洲精品小早川怜子| 亚洲日本护士毛茸茸| 日本欧美一区二区在线观看| 国产最新精品精品你懂的| 不卡一卡二卡三乱码免费网站| 在线观看欧美精品| 久久这里只有精品首页| 亚洲婷婷综合色高清在线| 日韩精品久久理论片| 99视频超级精品| 91精品国产美女浴室洗澡无遮挡| 国产午夜精品美女毛片视频| 亚洲成在线观看| 成人精品国产一区二区4080| 欧美老肥妇做.爰bbww| 中文无字幕一区二区三区| 中文字幕免费不卡| 国产米奇在线777精品观看| 99国产精品国产精品毛片| 国产福利视频一区二区三区| 精品国产乱码久久久久久闺蜜| 久久精品人人做人人综合| 亚洲一区二区中文在线| 国产成人免费在线观看不卡| av一区二区三区在线| 日韩欧美电影在线|