写脚本时,给脚本加参数
os.Args
os.Args为切片类型,是用户传入的参数
$ ./args_demo a b c d
args[0]=./args_demo //os.Args[0]
args[1]=a //os.Args[1]
args[2]=b //os.Args[2]
args[3]=c //os.Args[3]
args[4]=d //os.Args[4]
flag包
flag包是处理 `./args_demo -name=alex -age=12 --sexy=male` 这种参数的
flag.Type() // 返回指针类型
Type可以为:bool
、int
、int64
、uint
、uint64
、float
float64
、string
、duration
flag参数 | 有效值 |
---|---|
字符串 | 合法字符串 |
整数 | 1234、0664、0x1234等类型,也可以是负数。 |
浮点数 | 合法浮点数 |
bool类型 | 1, 0, t, f, T, F, true, false, TRUE, FALSE, True, False。 |
时间段 | 任何合法的时间段字符串。如”300ms”、”-1.5h”、”2h45m”。 合法的单位有”ns”、”us” /“µs”、”ms”、”s”、”m”、”h”。 |
demo:
package main
import ("fmt""flag")
func main() {name := flag.String("name", "张三", "姓名") // 参数1:-name 参数2:默认值 参数3:提示信息age := flag.Int("age", 18, "年龄")married := flag.Bool("married", false, "婚否")delay := flag.Duration("d", 0, "时间间隔")flag.Parse()fmt.Println(*name, *age, *married, *delay) // zs 22 true 6h0m0s/*`main.exe -name=zs -age=22 -married=true -d=6h`*/}
flag.TypeVar() // flag.TypeVar(Type指针, flag名, 默认值, 帮助信息)
demo:
package main
import ("fmt""flag""time")
func main() {var (name stringage intmarried booldelay time.Duration)flag.StringVar(&name, "name", "张三", "姓名")flag.IntVar(&age, "age", 18, "年龄")flag.BoolVar(&married, "married", false, "婚否")flag.DurationVar(&delay, "d", 0, "时间间隔")flag.Parse()fmt.Println(name, age, married, delay) // zs 22 true 6h0m0s/*`main.exe -name=zs -age=22 -married=true -d=6h`*/}
flag.Parse()
定义好命令行flag参数后,需要通过调用flag.Parse()
来对命令行参数进行解析。
支持的命令行参数格式有以下几种:
-flag xxx
(使用空格,一个-
符号)--flag xxx
(使用空格,两个-
符号)-flag=xxx
(使用等号,一个-
符号)--flag=xxx
(使用等号,两个-
符号)
其中,布尔类型的参数必须使用等号的方式指定。Flag解析在第一个非flag参数(单个”-“不是flag参数)之前停止,或者在终止符”–“之后停止。
flag其他参数:
flag.Args() ////返回命令行参数后的其他参数,以[]string类型
flag.NArg() //返回命令行参数后的其他参数个数
flag.NFlag() //返回使用的命令行参数个数