经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 程序设计 » Go语言 » 查看文章
Go-命令行参数解析
来源:cnblogs  作者:梦_鱼  时间:2024/1/24 9:43:07  对本文有异议

1. 解析命令行参数

程序在执行时,获取在命令行启动程序是使用的参数

  • 命令行( Command line interface -- CLI):基于文本来查看、处理、操作计算机的界面,又被称为 终端、控制台
  • 命令:在命令行执行的程序,一般是一行,包含命令名字、子命令与命令相关的选项(Flag),
  • Flag:传递给命令的参数,通过参数全称或者参数首字符指定参数名称,参数之后使用=或空格连接参数与参数值

2. Golang 获取命令行参数

  • os.Args: 返回一个字符串slice,第一个当前程序自身路径,剩余参数是传递给命令行的参数

    传递的参数一般是 --key=value 形式 、简写 -k value 形式或者是一个开关标志 -k,使用os.Args只是获取一个以空格分隔的字符串列表,无法很好的解析传递进来的参数到变量中

  1. package main
  2. import (
  3. "fmt"
  4. "os"
  5. )
  6. func main() {
  7. commandArgs := os.Args
  8. fmt.Println(commandArgs)
  9. }
  1. # 执行程序: 递归浏览指定目录下所有文件
  2. go run main.go --name ls --value /etc -r
  3. # 输出: [/tmp/go-build2637413899/b001/exe/main --name ls --value /etc -r]
  • 命令行参数解析 -- flag包

需要知晓程序的命令行需要传递哪些参数,如果没有传递该参数,那么默认值是什么,参数的说明

  1. 使用flag的流程:
  2. 1. 初始化存放命令行参数的全局变量
  3. 2. main包的init函数中注册需要解析的命令行参数,包含参数的类型、参数存放到哪个变量、参数的名称、参数的默认值、参数的使用说明
  4. 3. 在定义解析命令行参数最后,添加 flag.Parse(),解析传递到程序的命令行参数到变量中
  5. 4. 主函数中通过全局变量引用命令行参
  6. 5. 运行主函数,通过 -<参数名>=<value> -<参数名> <value> 方式传参
  7. 解析命令行参数的基本文法:
  8. 1. flag.<类型>Var(<指针>, <参数名称>, <默认值>, <用法说明>)
  9. 2. 等价方法: flag.<类型>(<参数名称>, <默认值>, <用法说明>)
  10. - 区别在于,Var后缀方法是通过指针将值存放到指针指向的变量,未带Var后缀的方法返回一个指定值的指针
  11. - 相同的,参数值不同则使用不同的类型,都包含参数的名称、参数的默认值、该参数使用说明
  12. - 类型是基本数据类型:int int64 uint uint64 string bool fl0at64 Duration
  1. package main
  2. import (
  3. "flag"
  4. "fmt"
  5. )
  6. // 1. 声明保存命令行参数的变量
  7. var (
  8. name string
  9. value string
  10. isRecursive bool
  11. )
  12. func init() {
  13. // 2. 注册需要解析的命令行参: 参数名、默认值、参数说明
  14. flag.StringVar(&name, "name", "none", "执行命令的名称")
  15. flag.StringVar(&value, "value", "none", "执行命令的参数")
  16. flag.BoolVar(&isRecursive, "recursive", false, "是否递归")
  17. // 3. 解析命令行参数
  18. flag.Parse()
  19. }
  20. func main() {
  21. // 4. 主程序中通过全局变量引用命令行参
  22. fmt.Println(name, value, isRecursive)
  23. }
  1. # 输出:ls /etc true
  2. go run main.go -name ls -value /etc -recursive
  3. # 输出: ls /etc false
  4. go run main.go -name ls -value /etc

Flag包相关的其他方法

  • flag.Set()解析后修改或设置命令行参数
  1. package main
  2. import (
  3. "flag"
  4. "fmt"
  5. )
  6. // 1. 声明保存命令行参数的变量
  7. var (
  8. name string
  9. )
  10. func init() {
  11. // 2. 声明需要解析的命令行参: 参数名、默认值、参数说明
  12. flag.StringVar(&name, "name", "none", "执行命令的名称")
  13. // 将name的值修改为 find
  14. flag.Set("name", "find")
  15. }
  16. func main() {
  17. // 4. 主程序中通过全局变量引用命令行参
  18. fmt.Println(name)
  19. }
  1. # 输出:find
  2. go run main.go -name ls
  • flog.NFlag() 返回被设置的flag数量
  1. package main
  2. import (
  3. "flag"
  4. "fmt"
  5. )
  6. // 1. 声明保存命令行参数的变量
  7. var (
  8. name string
  9. value string
  10. isRecursive bool
  11. )
  12. func init() {
  13. flag.StringVar(&name, "name", "none", "执行命令的名称")
  14. flag.StringVar(&value, "value", "none", "执行命令的参数")
  15. flag.BoolVar(&isRecursive, "recursive", false, "是否递归")
  16. flag.Parse()
  17. }
  18. func main() {
  19. fmt.Println("number of set flag:", flag.NFlag())
  20. }
  1. # 输出:number of set flag: 2
  2. go run main.go -name ls -value /etc
  • flag,Parsed() 检查 flag.Parse()是否被调用过
  1. package main
  2. import (
  3. "flag"
  4. "fmt"
  5. )
  6. // 1. 声明保存命令行参数的变量
  7. var (
  8. name string
  9. value string
  10. isRecursive bool
  11. )
  12. func init() {
  13. flag.StringVar(&name, "name", "none", "执行命令的名称")
  14. flag.StringVar(&value, "value", "none", "执行命令的参数")
  15. flag.BoolVar(&isRecursive, "recursive", false, "是否递归")
  16. flag.Parse()
  17. }
  18. func main() {
  19. fmt.Println("is Parsed", flag.Parsed())
  20. }
  1. # 输出:is Parsed true
  2. go run main.go -name ls -value /etc
  • flag.Visit(func (*Flag)) 按字典顺序遍历,进行设置了的标签
  1. package main
  2. import (
  3. "flag"
  4. "fmt"
  5. )
  6. // 1. 声明保存命令行参数的变量
  7. var (
  8. name string
  9. value string
  10. isRecursive bool
  11. )
  12. func init() {
  13. flag.StringVar(&name, "name", "none", "执行命令的名称")
  14. flag.StringVar(&value, "value", "none", "执行命令的参数")
  15. flag.BoolVar(&isRecursive, "recursive", false, "是否递归")
  16. flag.Parse()
  17. }
  18. func main() {
  19. flag.Visit(func(f *flag.Flag) {
  20. fmt.Printf("Name: %s, Value: %s, DefValue: %s, Usage: %s \n", f.Name, f.Value, f.DefValue, f.Usage)
  21. })
  22. }
  1. # 输出:
  2. # Name: name, Value: ls, DefValue: none, Usage: 执行命令的名称
  3. # Name: value, Value: /etc, DefValue: none, Usage: 执行命令的参数
  4. go run main.go -name ls -value /etc

原文链接:https://www.cnblogs.com/2bjiujiu/p/17983175

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号