Google开源命令行解析工具gflags

转自:https://blog.csdn.net/achelloworld/article/details/41959595#

gflags是google开源的一套命令行参数解析工具,支持C++和Python语言,其使用方法;

1. 定义参数

   使用gflags需要包含头文件#include <gflags/gflags.h>。将需要的命令行参数使用gflags的宏:DEFINE_xxxxx(变量名,默认值,help-string) 定义在文件当中,定义的参数是全局的,gflags支持的参数类型有:

DEFINE_bool:   boolean
DEFINE_int32:  32-bit integer
DEFINE_int64:  64-bit integer
DEFINE_uint64: unsigned 64-bit integer
DEFINE_double: double
DEFINE_string: C++ string

  定义方式如下:

DEFINE_bool(is,true,"Hello World");
DEFINE_string(str,"python","language");

  DEFINE_* 宏的三个参数分别代表命令行参数名,参数默认值,参数的帮助信息.

  gflags不支持列表,但是可以借助string类型实现,比如:

DEFINE_string(languages,"English, Chinese,Japanese","Select languages?");

2. 参数访问

  参数被定义后,可以通过FLAGS_name来访问对应的命令行参数,比如:

printf("%s", FLAGS_str);snprintf(language, MAX_LEN, "%s", FLAGS_languages.c_str());if(FLAGS_languages.find("English")!=string::npos){  isEnglish();  return 0;}

  通过DEFINE定义的参数,要保证访问变量的文件和定义参数的文件是同一个文件或者是头文件包含关系,否则将会访问不到定义的参数。

  在其他文件中使用定义的flags变量:有些时候需要在main之外的文件使用定义的flags变量,这时候可以使用宏定义DECLARE_xxx(变量名)声明一下(就和c++中全局变量的使用是一样的,extern一下一样)

DECLARE_bool: boolean
DECLARE_int32: 32-bit integer
DECLARE_int64: 64-bit integer
DECLARE_uint64: unsigned 64-bit integer
DECLARE_double: double
DECLARE_string: C++ string
  在gflags的doc中,推荐在对应的.h文件中进行DECLARE_xxx声明,需要使用的文件直接include就行了。

3. 参数检查

  检验输入参数是否合法:gflags库支持定制自己的输入参数检查的函数,参数定义后,可以为参数注册一个检查函数,当从命令行指定参数或通过SetCommandLineOption()指定参数时,检查函数就会被调用,两个参数分别为命令行参数名,以及设置的参数值。

#include <iostream>
#include <string.h>
#include <string>
#include <stdio.h>

#include <gflags/gflags.h>

using namespace std;
using namespace google;

static bool ValidatePort(const char *flagname, int32_t val)
{
    if(val > 0 && val < 32768)
        return true;   printf("Invalid value for --%s:%d\n",flagname,(int)val);
    return false;
}
DEFINE_int32(port, 6379, "what is the port ?");

int main(int argc, char **argv)
{
    ParseCommandLineFlags(&argc, &argv, true);
    bool isPort = RegisterFlagValidator(&FLAGS_port, &ValidatePort);
    return 0;
}

  建议在定义参数后,立即注册检查函数。RegisterFlagValidator()在检查函数注册成功时返回true; 如果参数已经注册了检查函数,或者检查函数类型不匹配,返回false。

4. 初始化参数

  通过调用ParseCommandLineFlags(&argc, &argv, true)实现,最后一个参数如果为true,gflags会移除Parse过的参数,如果为false则会保留。可能会对参数顺序进行调整。

5. 在命令行指定参数

  可以通过:--参数名=参数值 来指定。例如下面代码:

#include <iostream>
#include <string.h>
#include <string>
#include <stdio.h>

#include <gflags/gflags.h>

using namespace std;
using namespace google;

static bool ValidatePort(const char *flagname, int32_t val)
{
    if(val > 0 && val < 32768)
        return true;
    return false;
}
DEFINE_int32(port, 6379, "what is the port ?");
DEFINE_string(ip, "127.0.0.1", "My ip ?");

int main(int argc, char **argv)
{
    ParseCommandLineFlags(&argc, &argv, true);
    bool isPort = RegisterFlagValidator(&FLAGS_port, &ValidatePort);
    int32_t Port = FLAGS_port;
    string Ip = FLAGS_ip;
    cout << Port << endl;
    cout << Ip << endl;
    return 0;
}

  参数可以通过下面方式指定,参数之间可以没有顺序。

6. 定制你自己的help信息与version信息

  gflags里面已经定义了-h和--version,你可以通过以下方式定制它们的内容

version信息:使用google::SetVersionString设定,使用google::VersionString访问
help信息:使用google::SetUsageMessage设定,使用google::ProgramUsage访问
注意:google::SetUsageMessage和google::SetVersionString必须在google::ParseCommandLineFlags之前执行

7. 一些特殊的参数认识

  --help

打印定义过的所有参数的帮助信息

--version

打印版本信息 通过google::SetVersionString()指定

--nodefok

但命令行中出现没有定义的参数时,并不退出(error-exit)

--fromenv

从环境变量读取参数值 --fromenv=foo,bar表明要从环境变量读取foo,bar两个参数的值。通过

export FLAGS_foo=xxx; export FLAGS_bar=yyy 程序就可读到foo,bar的值分别为xxx,yyy。

--tryfromenv 

与--fromenv类似,当参数的没有在环境变量定义时,不退出(fatal-exit)

--flagfile

从文件读取参数值,--flagfile=my.conf表明要从my.conf文件读取参数的值。在配置文件中指定参

数值与在命令行方式类似,另外在flagfile里可进一步通过--flagfile来包含其他的文件。

  

原文地址:https://www.cnblogs.com/kerngeeksund/p/10922267.html

时间: 2024-07-31 02:34:04

Google开源命令行解析工具gflags的相关文章

python之命令行解析工具argparse

以前写python的时候都会自己在文件开头写一个usgae函数,用来加上各种注释,给用这个脚本的人提供帮助文档. 今天才知道原来python已经有一个自带的命令行解析工具argparse,用了一下,效果还不错. argparse的官方文档请看 https://docs.python.org/2/howto/argparse.html#id1 from argparse import ArgumentParser p = ArgumentParser(usage='it is usage tip'

转:python命令行解析工具Argparse

转自:http://www.cnblogs.com/jianboqi/archive/2013/01/10/2854726.html 最近在研究pathon的命令行解析工具,argparse,它是Python标准库中推荐使用的编写命令行程序的工具. 以前老是做UI程序,今天试了下命令行程序,感觉相当好,不用再花大把时间去研究界面问题,尤其是vc++中尤其繁琐. 现在用python来实现命令行,核心计算模块可以用c自己写扩展库,效果挺好. 学习了argparse,在官方文档中找到一篇toturia

Google开源命令行参数解析库gflags

http://blog.csdn.net/lming_08/article/details/25072899 CMDLINE的解析 http://blog.csdn.net/codectq/article/details/17078253 cmdline —— 轻量级的C++命令行解析库 http://www.tuicool.com/articles/z2q2mmm 下载url: https://github.com/tanakh/cmdline https://github.com/gssco

python命令行解析工具argparse模块【1】

argpaser是python中很好用的一个命令行解析模块,使用它我们可以很方便的创建用户友好型命令行程序.而且argparse会自动生成帮助信息和错误信息. 一.示例 例如下面的例子,从命令行中获取几个整数,然后获取它们的和或者最大值. import argparse parser = argparse.ArgumentParser(description='Process some integers.') parser.add_argument('integers', metavar='N'

Python中最好用的命令行解析工具:argparse

Python 做为一个脚本语言,可以很方便地写各种工具.当你在服务端要运行一个工具或服务时,输入参数似乎是一种硬需(当然你也可以通过配置文件来实现). 如果要以命令行执行,那你需要解析一个命令行参数解析的模块来帮你做这个苦力活. Python 本身就提供了三个命令行参数解析模块,我这里罗列一下它们的大致情况供你了解. getopt,只能简单的处理命令行参数 optparse,功能强大,易于使用,可以方便地生成标准的.符合Unix/Posix 规范的命令行说明.(Python2.7以后弃用,不会继

python命令行解析工具argparse模块【3】

上一节,我们讲解了ArgumentParser对象,这一节我们将学习这个对象的add_argument()方法. add_argument()方法的定义了如何解析一个命令行参数,每个参数都有各自独立的设置参数. 1.name or flags add_argument()必须知道参数是可选的还是必须的位置参数,第一个传递给add_arguments的参数必须是可选参数或者是位置参数,例如,下面是可选参数. >>> parser.add_argument('-f','--foo') 而位置

python命令行解析工具argparse模块【4】

上一节我们讲解了add_argument()方法,这一节我们将学习parse_args()方法. parse_args()方法的作用是解析命令行参数,并返回解析之后的命名空间.默认的,参数从sys.argv中获取.       1.参数值语法 parse_args()支持多种语法来解析参数,最简单的方式如下,参数与值分开传递 >>> parser = argparse.ArgumentParser(prog='PROG') >>> parser.add_argument

Windows 命令行解析工具(getopt)

忘记了上次在哪里找到这个功能库,只有一个 .h 和 .c 文件,再次搜索的时候发现找不到了,结果只能在之前的代码中,两个文件提出使用,顾将这两个文件备份在这里. 1 /* Getopt for Microsoft C 2 This code is a modification of the Free Software Foundation, Inc. 3 Getopt library for parsing command line argument the purpose was 4 to p

命令行解析工具argparse简单使用-1

1.基本使用#01.py import argparse parser = argparse.ArgumentParser()    parser.parse_args() $ python 01.py$$ python 01.py --helpusage: 01.py [-h] optional arguments:  -h, --help  show this help message and exit 2.位置参数#02.py import argparse parser = argpar