Ricerca…


Argomenti della riga di comando

L'analisi degli argomenti della riga di comando è Go è molto simile alle altre lingue. Nel tuo codice ti basta accedere a una serie di argomenti in cui il primo argomento sarà il nome del programma stesso.

Esempio veloce:

package main

import (
    "fmt"
    "os"
)

func main() {

    progName := os.Args[0]
    arguments := os.Args[1:]

    fmt.Printf("Here we have program '%s' launched with following flags: ", progName)

    for _, arg := range arguments {
        fmt.Printf("%s ", arg)
    }

    fmt.Println("")
}

E l'output sarebbe:

$ ./cmd test_arg1 test_arg2
Here we have program './cmd' launched with following flags: test_arg1 test_arg2

Ogni argomento è solo una stringa. Nel pacchetto os sembra: var Args []string

bandiere

Vai alla libreria standard fornisce il flag pacchetto che aiuta con i flag di analisi passati al programma.

Nota che il pacchetto flag non fornisce i normali flag stile GNU. Ciò significa che i flag di più lettere devono essere avviati con un trattino singolo come questo: -exampleflag , non questo: --exampleflag . I flag in stile GNU possono essere fatti con alcuni pacchetti di terze parti.

package main

import (
    "flag"
    "fmt"
)

func main() {

    // basic flag can be defined like this:
    stringFlag := flag.String("string.flag", "default value", "here comes usage")
    // after that stringFlag variable will become a pointer to flag value

    // if you need to store value in variable, not pointer, than you can
    // do it like:
    var intFlag int
    flag.IntVar(&intFlag, "int.flag", 1, "usage of intFlag")

    // after all flag definitions you must call
    flag.Parse()

    // then we can access our values
    fmt.Printf("Value of stringFlag is: %s\n", *stringFlag)
    fmt.Printf("Value of intFlag is: %d\n", intFlag)

}

flag fa il messaggio di aiuto per noi:

$ ./flags -h
Usage of ./flags:
  -int.flag int
        usage of intFlag (default 1)
  -string.flag string
        here comes usage (default "default value")

Chiama con tutte le bandiere:

$ ./flags -string.flag test -int.flag 24
Value of stringFlag is: test
Value of intFlag is: 24

Chiama con bandiere mancanti:

$ ./flags
Value of stringFlag is: default value
Value of intFlag is: 1


Modified text is an extract of the original Stack Overflow Documentation
Autorizzato sotto CC BY-SA 3.0
Non affiliato con Stack Overflow