Go 命令列參數及標準輸入輸出
標籤(空格分隔): Go 1.Go 命令列參數的使用 Go的命令列參數儲存在切片 os.Args 當中,可以說和python的命令列參數非常相似
fmt.Println(os.Args)//列印切片內容for i := 0; i < len(os.Args); i++ { fmt.Println(os.Args[i])}
其中第一個參數為可執行檔的名字,其他的參數都是以字串的形式,儲存在slice os.Args當中,可以通過for range 語句來遍曆所有的參數
for i, args := range os.Args { fmt.Printf("args[%d]=%s\n",i,args)}
2. flag包對命令列參數的解析 上面的參數解析只是從命令列當中把參數儲存在os.Args切片當中,應用的時候,不是很方便,特別是,編譯好的一個可執行檔,別人不知道如何使用的時候,可以使用Go內建的flag包對參數進行說明,並可設定預設值。 flag包的使用方法
flag.Type("flagName",defaultValue,"help message") *Type
flag包依據Type的類型,和參數標誌flagName,對標誌flagName設定預設值和協助資訊,最終返回一個指向該類型的指標,可以通過指標是否為空白來判斷命令列裡是否使用該標誌參數,下面是一個例子。
import( "flag" "fmt")var n = flag.Int("n",1,"number of page")var s = flag.String("s","nothing","info")func main() { flag.Parse() fmt.Println(*n) fmt.Println(*s)}
執行./cmd –help 可以看到設定的參數協助資訊
一般會在main函數開始之前的init函數當中使用參數的設定,這樣可以在main函數當中直接使用 3.標準輸入輸出
標準輸入輸出,在平時程式當中非常常用,一般讀取,列印等
從標準輸入讀取資料
func main() { input := bufio.NewScanner(os.Stdin)//初始化一個掃表對象 for input.Scan() {//掃描輸入內容 line := input.Text()//把輸入內容轉換為字串 fmt.Println(line)//輸出到標準輸出 }}