go語言的命令行庫


 

 

命令行應用通常很小,程序猿們也不喜歡為它編寫注釋。所以一些額外的工作,如解析參數有個合理的庫來幫忙做就好了。
https://github.com/urfave/cli 這個項目因此而生。
安裝:go get github.com/urfave/cli
以下的例子均來自官網:

(例1)

package main

import (
  "os"

  "github.com/urfave/cli"
)

func main() {
  cli.NewApp().Run(os.Args)
}

 

(例2)

package main

import (
  "fmt"
  "os"

  "github.com/urfave/cli"
)

func main() {
  app := cli.NewApp()
  app.Name = "greet"
  app.Usage = "fight the loneliness!"
  app.Action = func(c *cli.Context) error {
    fmt.Println("Hello friend!")
    return nil
  }

  app.Run(os.Args)
}

 

(例3)

package main

import (
  "fmt"
  "os"

  "github.com/urfave/cli"
)

func main() {
  app := cli.NewApp()

  app.Action = func(c *cli.Context) error {
    fmt.Printf("Hello %q\n", c.Args().Get(0))
    return nil 
  }

  app.Run(os.Args)
}

 

 

 (例4)

package main

import (
  "fmt"
  "os"

  "github.com/urfave/cli"
)

func main() {
  app := cli.NewApp()

  app.Flags = []cli.Flag {
    cli.StringFlag{
      Name: "lang",
      Value: "english",
      Usage: "language for the greeting",
    },
  }

  app.Action = func(c *cli.Context) error {
    name := "Nefertiti"
    if c.NArg() > 0 {
      name = c.Args().Get(0)
    }
    if c.String("lang") == "spanish" {
      fmt.Println("Hola", name)
    } else {
      fmt.Println("Hello", name)
    }
    return nil
  }

  app.Run(os.Args)
}

 

還有幾個小例子,情況差不多,請自行閱讀。

 

 

然而,事情到這里並沒有結束。。。

參數的解析還可以從yaml和toml里面獲取,這是兩個什么東東?

經常寫配置文件的會用到ini, xml, json格式;后2個寫起來太虐心,ini語法舒服但結構性缺陷決定它只能寫簡單配置。

因此yaml誕生(2001年)了,阮一峰在幾個月前寫了一篇教程:http://www.ruanyifeng.com/blog/2016/07/yaml.html

yaml不斷發展,此后日益復雜,導致積重難返,github創始人主導了一個新的項目toml:http://mlworks.cn/posts/introduction-to-toml/

從語法簡單性來說:ini > toml > yaml > json > xml

個人認為,沒有必要強上yaml/toml,簡單的用ini,稍復雜的json,很復雜的xml。

 

urfave/cli使用yaml/toml:

待補充。。。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM