用go的flag包来解析命令行参数

      go真是太贴心了, 来看看用go的flag包来解析命令行参数:

package main

import(
	"flag"
	"fmt"
	)

func main() {
	var l = flag.Int("l", 0, "para l is for len")
	var c = flag.String("c", "nothing", "para c is for content")
	flag.Parse()
	fmt.Println(*l)
	fmt.Println(*c)
	flag.Usage()
}

      看下结果:

ubuntu@VM-0-15-ubuntu:~/taoge/go$ go build test.go 
ubuntu@VM-0-15-ubuntu:~/taoge/go$ ./test 
0
nothing
Usage of ./test:
  -c string
     para c is for content (default "nothing")
  -l int
     para l is for len
ubuntu@VM-0-15-ubuntu:~/taoge/go$ 
ubuntu@VM-0-15-ubuntu:~/taoge/go$ 
ubuntu@VM-0-15-ubuntu:~/taoge/go$ 
ubuntu@VM-0-15-ubuntu:~/taoge/go$ ./test -l1 -ca
flag provided but not defined: -l1
Usage of ./test:
  -c string
     para c is for content (default "nothing")
  -l int
     para l is for len
ubuntu@VM-0-15-ubuntu:~/taoge/go$ 
ubuntu@VM-0-15-ubuntu:~/taoge/go$ 
ubuntu@VM-0-15-ubuntu:~/taoge/go$ 
ubuntu@VM-0-15-ubuntu:~/taoge/go$ ./test -l=1 -c=a
1
a
Usage of ./test:
  -c string
     para c is for content (default "nothing")
  -l int
     para l is for len
ubuntu@VM-0-15-ubuntu:~/taoge/go$ 
ubuntu@VM-0-15-ubuntu:~/taoge/go$ 
ubuntu@VM-0-15-ubuntu:~/taoge/go$ 
ubuntu@VM-0-15-ubuntu:~/taoge/go$ ./test -l 1 -c a
1
a
Usage of ./test:
  -c string
     para c is for content (default "nothing")
  -l int
     para l is for len
ubuntu@VM-0-15-ubuntu:~/taoge/go$ 
ubuntu@VM-0-15-ubuntu:~/taoge/go$ 
ubuntu@VM-0-15-ubuntu:~/taoge/go$ 
ubuntu@VM-0-15-ubuntu:~/taoge/go$ ./test  -c ab  -l 2
2
ab
Usage of ./test:
  -c string
     para c is for content (default "nothing")
  -l int
     para l is for len
ubuntu@VM-0-15-ubuntu:~/taoge/go$ 
ubuntu@VM-0-15-ubuntu:~/taoge/go$ 
ubuntu@VM-0-15-ubuntu:~/taoge/go$ 
ubuntu@VM-0-15-ubuntu:~/taoge/go$ ./test  -l 234
234
nothing
Usage of ./test:
  -c string
     para c is for content (default "nothing")
  -l int
     para l is for len
ubuntu@VM-0-15-ubuntu:~/taoge/go$ 
ubuntu@VM-0-15-ubuntu:~/taoge/go$ 
ubuntu@VM-0-15-ubuntu:~/taoge/go$ 
ubuntu@VM-0-15-ubuntu:~/taoge/go$ ./test  -l 234  -s abc
flag provided but not defined: -s
Usage of ./test:
  -c string
     para c is for content (default "nothing")
  -l int
     para l is for len
ubuntu@VM-0-15-ubuntu:~/taoge/go$ 

         练练手, 不多说。

 

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
Go语言中的flag包提供了一种方便的方式来解析命令行参数。它可以将命令行参数解析为Go语言中的变量,并提供了一些选项来设置默认值、帮助信息等。 下面是一个简单的示例,演示如何使用flag包来解析命令行参数: ```go package main import ( "flag" "fmt" ) func main() { // 定义命令行参数 var name string var age int var married bool flag.StringVar(&name, "name", "张三", "姓名,默认张三") flag.IntVar(&age, "age", 18, "年龄,默认18") flag.BoolVar(&married, "married", false, "婚否,默认false") // 解析命令行参数 flag.Parse() // 输出命令行参数 fmt.Printf("姓名:%s\n", name) fmt.Printf("年龄:%d\n", age) fmt.Printf("婚否:%v\n", married) } ``` 在这个示例中,我们使用了`flag.StringVar`、`flag.IntVar`和`flag.BoolVar`来定义命令行参数,分别对应字符串、整数和布尔类型。这些函数都接受三个参数:一个指向变量的指针,参数名称和参数默认值。我们还可以使用`flag.Parse()`来解析命令行参数,并在程序中使用这些参数。 在命令行中运行这个程序,可以使用以下命令行参数: ```shell ./example -name=李四 -age=20 -married=true ``` 这将输出: ``` 姓名:李四 年龄:20 婚否:true ``` 我们还可以使用`flag.Usage`来设置命令行帮助信息,例如: ```go flag.Usage = func() { fmt.Fprintf(os.Stderr, "Usage: %s [OPTIONS]\n", os.Args[0]) flag.PrintDefaults() } ``` 这将在命令行中运行程序时显示帮助信息。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值