类似 go get –u 的命令行参数实现

我们可能需要类似 go get –u …. 这样的方式来实现我们的应用,这时候我们无法简单地使用 flag.Parse 了,而是要用 FlagSet 了, 使用例子如下:

 

package main

import (
    "flag"
    "log"
    "os"
)

var ()

func main() {

    // 读取命令参数,注意,这里根据执行任务的不同,参数也不一样
    // 技术参考:
    // http://stackoverflow.com/questions/24504024/defining-independent-flagsets-in-golang
    // http://play.golang.org/p/eaEEx_EReX
    if len(os.Args) <= 1 {
        log.Println("请输入命令,支持的命令: esb、web、host!")
        os.Exit(-1)
    }
    log.Println(os.Args[1])
    cmd := os.Args[1]

    // esb 客户端工具
    fesb := flag.NewFlagSet("fesb", flag.ContinueOnError)
    consumer := fesb.Int("c", 0, "ESB 关系中过滤消费者的编号,不输代表全部。")
    provider := fesb.Int("p", 0, "ESB 关系中过滤生产者的编号,不输代表全部。")
    dependType := fesb.String("t", "cache", "ESB关系依赖的类型,默认来自线上的缓存,可选项:config (数据库的配置),cache(线上调用的缓存)")

    // web 站点
    fweb := flag.NewFlagSet("fweb", flag.ContinueOnError)
    webPort := fweb.Int("p", 81, "WEB 站点使用的端口号。")

    // 修改host文件方式
    fhost := flag.NewFlagSet("fhost", flag.ContinueOnError)
    aaa := fhost.Bool("b", false, "test 参数!")

    switch cmd {
    case "esb":
        err := fesb.Parse(os.Args[2:])
        if err != nil {
            log.Println("esb 参数类型错误,", err)
            os.Exit(-1)
        }
        log.Println("dependType:", *dependType)
        log.Println("consumer:", *consumer)
        log.Println("provider:", *provider)

    case "web":
        err := fweb.Parse(os.Args[2:])
        if err != nil {
            log.Println("web 参数类型错误,", err)
            os.Exit(-1)
        }
        log.Println("webPort:", *webPort)

    case "host":
        err := fhost.Parse(os.Args[2:])
        if err != nil {
            log.Println("host 参数类型错误,", err)
            os.Exit(-1)
        }
        log.Println("aaa:", *aaa)

    }

}

参考资料:

http://play.golang.org/p/eaEEx_EReX

http://stackoverflow.com/questions/24504024/defining-independent-flagsets-in-golang

https://golang.org/pkg/flag/#NewFlagSet

时间: 2024-11-05 10:43:26

类似 go get –u 的命令行参数实现的相关文章

VB命令行参数分隔, 类似C语言中的main(int argc, char* argv[])

VB6.0为了提供命令行参数的支持,提供了Command()接口,于是通过 Command() 函数可以得到所有传入的参数,但是很不友好的是,VB的所有参数都被合在了一起,成为了一个字符串,当有多个参数时,要想使用就不那么方便了,于是,于是就有了下面的代码,代码我不记得是来自哪里了,如果你是文章的作者,请通知我一下[email protected]@ Option Explicit Private Declare Function GetCommandLineW Lib "kernel32&qu

第5章4节《MonkeyRunner源码剖析》Monkey原理分析-启动运行: 命令行参数解析(原创)

天地会珠海分舵注:本来这一系列是准备出一本书的,详情请见早前博文"寻求合作伙伴编写<深入理解 MonkeyRunner>书籍".但因为诸多原因,没有如愿.所以这里把草稿分享出来,所以错误在所难免.有需要的就参考下吧,转发的话还请保留每篇文章结尾的出处等信息. 设置好Monkey的CLASSPATH环境变量以指定"/system/framework /framework/monkey.jar"后,/system/bin/monkey这个shell脚本就会通

Python 命令行参数和getopt模块详解

1.需求来源 有时候我们需要写一些脚本处理一些任务,可能根据不同的条件输入不同的命令,来完成不同的任务.能不能做到跟linux操作系统一样,看着更高大上一点呢? 答案当然是可以的啦!getopt能满足你的需求 先看个linux 中的系统命令吧:最终目的就是写出类似的脚本. 2.getopt介绍 getopt这个函数 就是用来抽取 sys.argv 获得的用户输入来确定执行步骤. getopt是个模块,而这个模块里面又有getopt 函数,所以getopt需要这样这样用. getopt.getop

R语言使用命令行参数

args_test.R 代码如下: Args <- commandArgs()cat("Args[1]=",Args[1],"\n")cat("Args[2]=",Args[1],"\n")cat("Args[3]=",Args[3],"\n")cat("Args[4]=",Args[4],"\n")cat("Args[5]=&qu

第8章2节《MonkeyRunner源码剖析》MonkeyRunner启动运行过程-解析处理命令行参数

MonkeyRunnerStarter是MonkeyRunner启动时的入口类,因为它里面包含了main方法.它的整个启动过程主要做了以下几件事情: 解析用户启动MonkeyRunner时从命令行传输进来的参数: 因为MonkeyRunner需要根据指定的参数才能做事情,比如输入的一个需要执行的脚本.如果确实不知道任何参数的话它就会进入MonkeyRunner的交互模式,其实就是Jythong的交互模式,让用户可以边写代码边执行 启动AndroidDebugBridge: 其实就是启动ADB服务

(官网)虚幻3--虚幻引擎3命令行参数

虚幻引擎3命令行参数 虚幻引擎3命令行参数 概述 模式 地图/服务器/编辑器的URL 参数 一般选项 服务器选项 针对UTGame的特定选项 Switches(开关) 开发人员 渲染 网络 用户 服务器开关 游戏 统计数据/数据库 INI/Config 文件 调试 其它 概述 命令行参数是一连串的关键字字符串,当运行可执行文件时可以通过命令行或者可执行文件的快捷方式将其传入.它们的目的是自定义引擎运行的方式,以便符合开发人员或用户的需要.这可以像使得运行编辑器而不运行游戏那么简单;或它也可以更加

(二)NS3如何编译、运行脚本和 Command Line命令行参数设置

二.编译.运行脚本和Command Line命令行参数设置 7. 编译和运行脚本主要步骤 1) 将编写的脚本复制到ns-3.22/scratch目录下(可以在ubuntu窗口界面直接复制) 进入ns3目录: /ns-3.22 $ cp examples/tutorial/first.cc  scratch/myfirst.cc将脚本复制到scratch目录下 2) 构建(编译) $ ./waf 3) 运行 $ ./waf --run scratch/myfirst (可能会有运行权限问题,可在r

学习使用的PL/0编译器增强版PL/0plusplusCompiler(二)加入支持命令行参数

每次程序运行后输入源码文件名不是很好,于是做了支持命令行参数的改进.大体思路:在main函数入口加入命令行参数,进入main后判断文件名是否为空,为空就退出,否则就继续编译. 在main的括号中加入 int argc, char** argv 在main第一行加入 /*如果没有在命令行中输入文件名会提示输入源码文件名*/ if(argv[1]==NULL){ printf("请输入源程序!\n"); return; } 把这两行注释掉 // printf("Input pl/

Python处理命令行参数

1. 将命令行参数保存在列表中,注意argv[0]是程序本身的名字: import sys print(sys.argv) print(sys.argv[1]) python argv.py localhost 3306['argv.py', 'localhost', '3306']localhost 2. 使用sys.stdin和fileinput读取标准输入,并打印在终端类似shell中的管道 import sys for line in sys.stdin: print(line,end=