Go语言_flag_Go的命令行参数 /命令行处理
来源:互联网 发布:模拟教学软件 编辑:程序博客网 时间:2024/05/15 06:30
原文来自 :http://studygolang.com/articles/2878
1.命令行参数(命令行参数是指定程序运行参数的一个常见方式。例如,go run hello.go,程序 go 使用了 run 和 hello.go 两个参数。)
package mainimport "os"import "fmt"func main() { //os.Args 提供原始命令行参数访问功能。注意,切片中的第一个参数是该程序的路径,并且 os.Args[1:]保存所有程序的的参数。 argsWithProg := os.Args argsWithoutProg := os.Args[1:] //你可以使用标准的索引位置方式取得单个参数的值。 arg := os.Args[3] fmt.Println(argsWithProg) fmt.Println(argsWithoutProg) fmt.Println(arg)}/*要实验命令行参数,最好先使用 go build 编译一个可执行二进制文件$ go build command-line-arguments.go$ ./command-line-arguments a b c d[./command-line-arguments a b c d][a b c d]c*/
2.命令行标志(使用标记的命令行处理方法,命令行标志是命令行程序指定选项的常用方式。例如,在 wc -l 中,这个 -l 就是一个命令行标志。)
package main//Go 提供了一个 flag 包,支持基本的命令行标志解析。我们将用这个包来实现我们的命令行程序示例。import "flag"import "fmt"func main() { //基本的标记声明仅支持字符串、整数和布尔值选项。这里我们声明一个默认值为 "foo" 的字符串标志 word并带有一个简短的描述。这里的 flag.String 函数返回一个字符串指针(不是一个字符串值),在下面我们会看到是如何使用这个指针的。 wordPtr := flag.String("word", "foo", "a string") //使用和声明 word 标志相同的方法来声明 numb 和 fork 标志。 numbPtr := flag.Int("numb", 42, "an int") boolPtr := flag.Bool("fork", false, "a bool") //用程序中已有的参数来声明一个标志也是可以的。注意在标志声明函数中需要使用该参数的指针。 var svar string flag.StringVar(&svar, "svar", "bar", "a string var") //所有标志都声明完成以后,调用 flag.Parse() 来执行命令行解析。 flag.Parse() //这里我们将仅输出解析的选项以及后面的位置参数。注意,我们需要使用类似 *wordPtr 这样的语法来对指针解引用,从而得到选项的实际值。 fmt.Println("word:", *wordPtr) fmt.Println("numb:", *numbPtr) fmt.Println("fork:", *boolPtr) fmt.Println("svar:", svar) fmt.Println("tail:", flag.Args())}/*测试这个程序前,最好将这个程序编译成二进制文件,然后再运行这个程序。$ go build command-line-flags.goword: optnumb: 7fork: truesvar: flagtail: []注意到,如果你省略一个标志,那么这个标志的值自动的设定为他的默认值。$ ./command-line-flags -word=optword: optnumb: 42fork: falsesvar: bartail: []位置参数可以出现在任何标志后面。$ ./command-line-flags -word=opt a1 a2 a3word: opt...tail: [a1 a2 a3]注意,flag 包需要所有的标志出现位置参数之前(否则,这个标志将会被解析为位置参数)。$ ./command-line-flags -word=opt a1 a2 a3 -numb=7word: optnumb: 42fork: falsesvar: bartrailing: [a1 a2 a3 -numb=7]使用 -h 或者 --help 标志来得到自动生成的这个命令行程序的帮助文本。$ ./command-line-flags -hUsage of ./command-line-flags: -fork=false: a bool -numb=42: an int -svar="bar": a string var -word="foo": a string如果你提供一个没有使用 flag 包指定的标志,程序会输出一个错误信息,并再次显示帮助文本。$ ./command-line-flags -watflag provided but not defined: -watUsage of ./command-line-flags:...*/
1.命令行参数(命令行参数是指定程序运行参数的一个常见方式。例如,go run hello.go,程序 go 使用了 run 和 hello.go 两个参数。)
package mainimport "os"import "fmt"func main() { //os.Args 提供原始命令行参数访问功能。注意,切片中的第一个参数是该程序的路径,并且 os.Args[1:]保存所有程序的的参数。 argsWithProg := os.Args argsWithoutProg := os.Args[1:] //你可以使用标准的索引位置方式取得单个参数的值。 arg := os.Args[3] fmt.Println(argsWithProg) fmt.Println(argsWithoutProg) fmt.Println(arg)}/*要实验命令行参数,最好先使用 go build 编译一个可执行二进制文件$ go build command-line-arguments.go$ ./command-line-arguments a b c d[./command-line-arguments a b c d][a b c d]c*/
2.命令行标志(使用标记的命令行处理方法,命令行标志是命令行程序指定选项的常用方式。例如,在 wc -l 中,这个 -l 就是一个命令行标志。)
package main//Go 提供了一个 flag 包,支持基本的命令行标志解析。我们将用这个包来实现我们的命令行程序示例。import "flag"import "fmt"func main() { //基本的标记声明仅支持字符串、整数和布尔值选项。这里我们声明一个默认值为 "foo" 的字符串标志 word并带有一个简短的描述。这里的 flag.String 函数返回一个字符串指针(不是一个字符串值),在下面我们会看到是如何使用这个指针的。 wordPtr := flag.String("word", "foo", "a string") //使用和声明 word 标志相同的方法来声明 numb 和 fork 标志。 numbPtr := flag.Int("numb", 42, "an int") boolPtr := flag.Bool("fork", false, "a bool") //用程序中已有的参数来声明一个标志也是可以的。注意在标志声明函数中需要使用该参数的指针。 var svar string flag.StringVar(&svar, "svar", "bar", "a string var") //所有标志都声明完成以后,调用 flag.Parse() 来执行命令行解析。 flag.Parse() //这里我们将仅输出解析的选项以及后面的位置参数。注意,我们需要使用类似 *wordPtr 这样的语法来对指针解引用,从而得到选项的实际值。 fmt.Println("word:", *wordPtr) fmt.Println("numb:", *numbPtr) fmt.Println("fork:", *boolPtr) fmt.Println("svar:", svar) fmt.Println("tail:", flag.Args())}/*测试这个程序前,最好将这个程序编译成二进制文件,然后再运行这个程序。$ go build command-line-flags.goword: optnumb: 7fork: truesvar: flagtail: []注意到,如果你省略一个标志,那么这个标志的值自动的设定为他的默认值。$ ./command-line-flags -word=optword: optnumb: 42fork: falsesvar: bartail: []位置参数可以出现在任何标志后面。$ ./command-line-flags -word=opt a1 a2 a3word: opt...tail: [a1 a2 a3]注意,flag 包需要所有的标志出现位置参数之前(否则,这个标志将会被解析为位置参数)。$ ./command-line-flags -word=opt a1 a2 a3 -numb=7word: optnumb: 42fork: falsesvar: bartrailing: [a1 a2 a3 -numb=7]使用 -h 或者 --help 标志来得到自动生成的这个命令行程序的帮助文本。$ ./command-line-flags -hUsage of ./command-line-flags: -fork=false: a bool -numb=42: an int -svar="bar": a string var -word="foo": a string如果你提供一个没有使用 flag 包指定的标志,程序会输出一个错误信息,并再次显示帮助文本。$ ./command-line-flags -watflag provided but not defined: -watUsage of ./command-line-flags:...*/
0 0
- Go语言_flag_Go的命令行参数 /命令行处理
- Go语言程序的命令行参数
- 处理c语言的命令行参数
- 命令行编译运行Go语言时参数代入的问题
- Go获取命令行参数及信号量处理
- Go语言学习(八)获取命令行参数
- C语言处理命令行参数
- Go-命令行参数
- go programming language读书笔记一:go语言命令行参数
- python的命令行参数处理
- Linux环境C语言编程的命令行参数处理
- Go语言实现的命令行解析程序
- C语言的命令行参数
- C语言的命令行参数
- c语言的命令行参数
- C语言的命令行参数
- Go解析命令行传入参数
- 轻松处理命令行参数
- spring-autowire、集合等各种参数注入
- Eclipse中有用的快捷键
- 从苏宁电器到卡巴斯基第12篇:我在苏宁电器当营业员 IV
- 记一次神奇的优化过程:Java反射 VS Apache BeanUtils VS Spring BeanUtils
- 8、在MyEclipse中自动生成JUnit类
- Go语言_flag_Go的命令行参数 /命令行处理
- UE4源码分析1-下载源码
- mysql从linux命令行导入数据行中文字符的解决办法
- HDOJ-1102 Constructing Roads(最小生成树)两种做法
- checkstyle安装使用
- 2016计蒜之道 复赛 A. 百度地图的实时路况(cdq分治+floyd)
- android实现通过浏览器点击链接打开本地应用(APP)并拿到浏览器传递的数据
- HDU3001 Travelling
- NYOJ-大数阶乘