Go-命令行参数解析
1. 解析命令行参数
程序在执行时,获取在命令行启动程序是使用的参数
- 命令行( Command line interface -- CLI):基于文本来查看、处理、操作计算机的界面,又被称为 终端、控制台
- 命令:在命令行执行的程序,一般是一行,包含命令名字、子命令与命令相关的选项(Flag),
- Flag:传递给命令的参数,通过参数全称或者参数首字符指定参数名称,参数之后使用
=或空格连接参数与参数值
2. Golang 获取命令行参数
os.Args: 返回一个字符串slice,第一个当前程序自身路径,剩余参数是传递给命令行的参数
传递的参数一般是
--key=value形式 、简写-k value形式或者是一个开关标志-k,使用os.Args只是获取一个以空格分隔的字符串列表,无法很好的解析传递进来的参数到变量中
package main
import (
"fmt"
"os"
)
func main() {
commandArgs := os.Args
fmt.Println(commandArgs)
}
# 执行程序: 递归浏览指定目录下所有文件
go run main.go --name ls --value /etc -r
# 输出: [/tmp/go-build2637413899/b001/exe/main --name ls --value /etc -r]
- 命令行参数解析 -- flag包
需要知晓程序的命令行需要传递哪些参数,如果没有传递该参数,那么默认值是什么,参数的说明
使用flag的流程:
1. 初始化存放命令行参数的全局变量
2. 在main包的init函数中注册需要解析的命令行参数,包含参数的类型、参数存放到哪个变量、参数的名称、参数的默认值、参数的使用说明
3. 在定义解析命令行参数最后,添加 flag.Parse(),解析传递到程序的命令行参数到变量中
4. 主函数中通过全局变量引用命令行参
5. 运行主函数,通过 -<参数名>=<value> 或 -<参数名> <value> 方式传参
解析命令行参数的基本文法:
1. flag.<类型>Var(<指针>, <参数名称>, <默认值>, <用法说明>)
2. 等价方法: flag.<类型>(<参数名称>, <默认值>, <用法说明>)
- 区别在于,Var后缀方法是通过指针将值存放到指针指向的变量,未带Var后缀的方法返回一个指定值的指针
- 相同的,参数值不同则使用不同的类型,都包含参数的名称、参数的默认值、该参数使用说明
- 类型是基本数据类型:int int64 uint uint64 string bool fl0at64 Duration
package main
import (
"flag"
"fmt"
)
// 1. 声明保存命令行参数的变量
var (
name string
value string
isRecursive bool
)
func init() {
// 2. 注册需要解析的命令行参: 参数名、默认值、参数说明
flag.StringVar(&name, "name", "none", "执行命令的名称")
flag.StringVar(&value, "value", "none", "执行命令的参数")
flag.BoolVar(&isRecursive, "recursive", false, "是否递归")
// 3. 解析命令行参数
flag.Parse()
}
func main() {
// 4. 主程序中通过全局变量引用命令行参
fmt.Println(name, value, isRecursive)
}
# 输出:ls /etc true
go run main.go -name ls -value /etc -recursive
# 输出: ls /etc false
go run main.go -name ls -value /etc
Flag包相关的其他方法
flag.Set()解析后修改或设置命令行参数
package main
import (
"flag"
"fmt"
)
// 1. 声明保存命令行参数的变量
var (
name string
)
func init() {
// 2. 声明需要解析的命令行参: 参数名、默认值、参数说明
flag.StringVar(&name, "name", "none", "执行命令的名称")
// 将name的值修改为 find
flag.Set("name", "find")
}
func main() {
// 4. 主程序中通过全局变量引用命令行参
fmt.Println(name)
}
# 输出:find
go run main.go -name ls
flog.NFlag()返回被设置的flag数量
package main
import (
"flag"
"fmt"
)
// 1. 声明保存命令行参数的变量
var (
name string
value string
isRecursive bool
)
func init() {
flag.StringVar(&name, "name", "none", "执行命令的名称")
flag.StringVar(&value, "value", "none", "执行命令的参数")
flag.BoolVar(&isRecursive, "recursive", false, "是否递归")
flag.Parse()
}
func main() {
fmt.Println("number of set flag:", flag.NFlag())
}
# 输出:number of set flag: 2
go run main.go -name ls -value /etc
flag,Parsed()检查flag.Parse()是否被调用过
package main
import (
"flag"
"fmt"
)
// 1. 声明保存命令行参数的变量
var (
name string
value string
isRecursive bool
)
func init() {
flag.StringVar(&name, "name", "none", "执行命令的名称")
flag.StringVar(&value, "value", "none", "执行命令的参数")
flag.BoolVar(&isRecursive, "recursive", false, "是否递归")
flag.Parse()
}
func main() {
fmt.Println("is Parsed", flag.Parsed())
}
# 输出:is Parsed true
go run main.go -name ls -value /etc
flag.Visit(func (*Flag))按字典顺序遍历,进行设置了的标签
package main
import (
"flag"
"fmt"
)
// 1. 声明保存命令行参数的变量
var (
name string
value string
isRecursive bool
)
func init() {
flag.StringVar(&name, "name", "none", "执行命令的名称")
flag.StringVar(&value, "value", "none", "执行命令的参数")
flag.BoolVar(&isRecursive, "recursive", false, "是否递归")
flag.Parse()
}
func main() {
flag.Visit(func(f *flag.Flag) {
fmt.Printf("Name: %s, Value: %s, DefValue: %s, Usage: %s \n", f.Name, f.Value, f.DefValue, f.Usage)
})
}
# 输出:
# Name: name, Value: ls, DefValue: none, Usage: 执行命令的名称
# Name: value, Value: /etc, DefValue: none, Usage: 执行命令的参数
go run main.go -name ls -value /etc
Go-命令行参数解析的更多相关文章
- python命令行参数解析模块argparse和docopt
http://blog.csdn.net/pipisorry/article/details/53046471 还有其他两个模块实现这一功能,getopt(等同于C语言中的getopt())和弃用的o ...
- gflags命令行参数解析
gflags库是google开源的命令行参数解析工具. 安装 官方没有提供二进制库,但是Debian/Ubuntu平台本身提供了二进制库,可以直接git clone https://github.co ...
- [Go] 命令行参数解析包(flag 包)使用详解
Go 的 flag 包可以解析命令行的参数. 一.命令行语法 命令行语法主要有以下几种形式: cmd -flag // 只支持bool类型 cmd -flag=xxx cmd -flag ...
- $命令行参数解析模块argparse的用法
argparse是python内置的命令行参数解析模块,可以用来为程序配置功能丰富的命令行参数,方便使用,本文总结一下其基本用法. 测试脚本 把以下脚本存在argtest.py文件中: # codin ...
- Google开源命令行参数解析库gflags
Google开源命令行参数解析库gflags http://blog.csdn.net/lming_08/article/details/25072899 CMDLINE的解析 http://blog ...
- PHP 命令行参数解析工具类
<?php/** * 命令行参数解析工具类 * @author guolinchao * @email luoyecb@163.com */class CommandLine{ // store ...
- golang-flag - 命令行参数解析
flag - 命令行参数解析 在写命令行程序(工具.server)时,对命令参数进行解析是常见的需求.各种语言一般都会提供解析命令行参数的方法或库,以方便程序员使用.如果命令行参数纯粹自己写代码解析, ...
- Python命令行参数解析模块getopt使用实例
Python命令行参数解析模块getopt使用实例 这篇文章主要介绍了Python命令行参数解析模块getopt使用实例,本文讲解了使用语法格式.短选项参数实例.长选项参数实例等内容,需要的朋友可以参 ...
- python命令行参数解析OptionParser类用法实例
python命令行参数解析OptionParser类用法实例 本文实例讲述了python命令行参数解析OptionParser类的用法,分享给大家供大家参考. 具体代码如下: from opt ...
- Python 中命令行参数解析工具 docopt 安装和应用
什么是 docopt? 1.docopt 是一种 Python 编写的命令行执行脚本的交互语言. 它是一种语言! 它是一种语言! 它是一种语言! 2.使用这种语言可以在自己的脚本中,添加一些规则限制. ...
随机推荐
- 试试这 6 个小技巧,提升 EF Core 性能
Entity FrameWork(简称 EF)以面向对象的方式操作数据库给开发人员带来了很大的便利性,但其性能问题从面世以来就一直就被广大的 .NET 生态开发技术人员所吐槽,然而,它真的那么不堪使用 ...
- 9 个让你的 Python 代码更快的小技巧
哈喽大家好,我是咸鱼 我们经常听到 "Python 太慢了","Python 性能不行"这样的观点.但是,只要掌握一些编程技巧,就能大幅提升 Python 的运 ...
- Luogu P5515 [MtOI2019]灵梦的计算器
简化题意 给定三个实数 \(n, a, b\),求方程 \(\left \lfloor {x ^ a + x ^ b} \right \rfloor = \left \lfloor {n ^ a + ...
- CVE-2023-36025 Windows SmartScreen 安全功能绕过漏洞
CVE-2023-36025是微软于11月补丁日发布的安全更新中修复Windows SmartScreen安全功能绕过漏洞.攻击者可以通过诱导用户单击特制的URL来利用该漏洞,对目标系统进行攻击.成功 ...
- 【scikit-learn基础】--『监督学习』之 均值聚类
聚类算法属于无监督学习,其中最常见的是均值聚类,scikit-learn中,有两种常用的均值聚类算法:一种是有名的K-means(也就是K-均值)聚类算法,这个算法几乎是学习聚类必会提到的算法:另一个 ...
- C#判断字符串是否是有效的XML格式数据
说明 在try-catch语句块中,创建XmlDocument对象,并使用LoadXml方法加载xml字符串.如果没有异常,则说明xml字符串是有效的,返回true,反之为false. 代码实现 // ...
- GaussDB(DWS)集群中寻找节点CPU占用高的语句
摘要:本文主要通过实例讲解如何通过gs_cpuwatcher.sh 脚本寻找CPU占用高语句. 本文分享自华为云社区<GaussDB(DWS) gs_cpuwatcher.sh 脚本如何寻找CP ...
- 深度解析9种ScheduledThreadPoolExecutor的构造方法
摘要:今天我们就来一起手撕ScheduledThreadPoolExecutor类的源代码. 本文分享自华为云社区<深度解析ScheduledThreadPoolExecutor类的源代码> ...
- 顶会VLDB‘22论文解读:CAE-ENSEMBLE算法
摘要:针对时间序列离群点检测问题,提出了基于CNN-AutoEncoder和集成学习的CAE-ENSEMBLE深度神经网络算法,并通过大量的实验证明CAE-ENSEMBLE算法能有效提高时间序列离群点 ...
- 负载均衡 SLB 健康检查异常
负载均衡 SLB 健康检查异常,接口地址不能访问 接口地址的访问首先需要健康检查状态为正常. 如果接口没有"首页",需要提供一个可访问的controller