Apache Commons CLI
简单的说,就是对命令的参数进行定义和解析的工具 -- 这里说的参数是我们常用的说法,而CLI里则是Option、Options,参数值(如果有)则是Option的arg(s)。
## 为什么
那么,为什么要用这个工具呢?
因为在很多情况下,一个命令要包含很多参数及值,而有时候我们又需要生成这样的参数,或者获解析这样的参数。
如果使用字符串的切割或者正则来做,当然也不是不行,就是麻烦,特别是在参数顺序不定,参数值个数不定,参数和参数值的分隔符不定的时候,无疑是很令人头疼的一件事。
这个时候,就是轮到CLI出马了。
## 概念
CLI这个库很简单,1.3.1版本 只有22个Java文件,其中5个还是@Deprecated 。
需要掌握的概念 Options、Option、CommandLineParser、CommandLine、HelpFormatter。
以shell命令 “ls -l -a -w=5” 为例:
CLI概念 | 对应 |
CommandLine | “-l -a -w=5” |
Option | “-l”或”-a”或”-w”或”-S”或其他 |
Options | “-l”、”-a”、”-w”、”-S”等所有Option的集合 |
需要注意:
CommandLine 不包含 ”ls” 本身。
Option 有的是必选项,有的是可选项。
Option 有的是带有值的,如”-w”,其值在Option中叫arg,而arg又有可选/必需之分,一些参数还有个数的限制。
OK,基本概念就这么简单,进入代码阶段。
## Option
Option的创建有两种方式,使用构造器,或者使用Option.builder。
构造器方式如下:
// 最简单的构造:参数名、参数说明
Option option1 = new Option("-l", "长格式名字"); // 参数名、参数是否有值、参数说明
Option option2 = new Option("-a", false, "显示全部文件、文件夹"); // 参数名、长参数名、参数是否有值、参数说明
Option option3 = new Option("-C", "--color", true, "什么时候彩色输出,候选值always、never、auto");
Option.builder 方式如下:
Option optionColor = Option.builder("-C") //注意,不要漏掉"-"
.longOpt("--color") // 完整写法
.argName("颜色")
.desc("彩色输出设置")
.required(false) //该选项是否必需?
.hasArg(true) //该选项是否需要一个参数?因为有的选项不需要参数
.valueSeparator('=') //选项与参数连接的符号 -C=never
.numberOfArgs(1) //该选项最多能接收的参数
.optionalArg(false) //该选项的参数是否可选? 注意与required的区别
.type(String.class) //该选项的值的类型?
.build();
可以看出,builder方式更全面一些,当然,最终生成的Option对象都是可以再逐项修改的。
## Options
有了各个Option,就可以将其添加到Options中了。
Options options = new Options();
options.addOption(option); //将所有相关的Option都添加到Options中。
## CommandLineParser
有了Options,我们就有了限制条件,就可以对实际的参数进行解析了。
String[] args = {"-l", "-C=auto", "-w=5"}; //模拟。通常是获取到的,所以才需要解析。
CommandLine commandLine = commandLineParser.parse(options, args);
## CommandLine
拿到了CommandLine,我们就可以获取需要的参数及值了!
// 可以获取到指定参数的值
System.out.println(commandLine.getOptionValue("-a"));
System.out.println(commandLine.getOptionValue("-C"));
System.out.println(commandLine.getOptionValue("-w")); // 还可以判断是否存在某个参数,等等,略。
OK,至此 其实已经撸完了必需的功能,着急的话就已经可以开工了。
但是,CLI 还提供了两个小东西,很有意思的小东西:PatternOptionBuilder、HelpFormatter。
## PatternOptionBuilder
这是一个快速构建Options的工具类,约定了一些符号的用法,如”:”、”/”、”!”等。
a | -a flag |
b@ | -b [classname] |
c> | -c [filename] |
d+ | -d [classname] (creates object via empty constructor) |
e% | -e [number] (creates Double/Long instance depending on existing of a '.') |
f/ | -f [url] |
g: | -g [string] |
注意,上面的字母都是参数项,这里只能使用单个字母。
看例子吧:
// 快速构建一个Options,有三个参数 "-v"、"-p"、"-f",其中"-p"需要有参数值,且类型是字符串;"-f"不是必选项,其参数值为URL
Options options = PatternOptionBuilder.parsePattern("vp:!f/"); // 参数,其实获取到的参数都是line.split("\\s+"),就是字符串数组
String[] args = {"-v", "-p", "whereru", "-f", "http://www.baidu.com"}; CommandLine commandLine = commandLineParser.parse(options, args); System.out.println(commandLine.getOptionValue("v"));
System.out.println(commandLine.getOptionValue("p"));
System.out.println(commandLine.getOptionValue("f"));
怎么样,够简单吧
## HelpFormatter
这个工具类,顾名思义,就是格式化帮助信息用的。
不多说,运行下一下下面的代码就明白了:
// 输出命令的帮助信息(类似于shell中的 cmd --help的结果)
@Test
public void help(){
HelpFormatter helpFormatter = new HelpFormatter(); // 注意,下面这些setter都可以忽略
helpFormatter.setSyntaxPrefix(">>>");
helpFormatter.setArgName("参数的名字");
helpFormatter.setLeftPadding(4);
helpFormatter.setDescPadding(4);
helpFormatter.setOptPrefix("-");
helpFormatter.setLongOptPrefix("--");
helpFormatter.setNewLine("\r\n-------------------\r\n-------------------\r\n");
helpFormatter.setLongOptSeparator("==");
helpFormatter.setWidth(18); // 这里这里这里
helpFormatter.printHelp("python", PatternOptionBuilder.parsePattern("vp:!f/"));
}
呼,希望有所帮助。
Apache Commons CLI的更多相关文章
- Apache Commons CLI官方文档翻译 —— 快速构建命令行启动模式
昨天通过几个小程序以及Hangout源码学习了CLI的基本使用,今天就来尝试翻译一下CLI的官方使用手册. 下面将会通过几个部分简单的介绍CLI在应用中的使用场景. 昨天已经联系过几个基本的命令行参数 ...
- Apache Commons CLI命令行启动
今天又看了下Hangout的源码,一般来说一个开源项目有好几种启动方式--比如可以从命令行启动,也可以从web端启动.今天就看看如何设计命令行启动... Apache Commons CLI Apac ...
- Apache Commons CLI 简介
CLI 命令代码实现 命令行程序处理流程相对比较简单,主要流程为设定命令行参数 -> 解析输入参数 -> 使用输入的数据进行逻辑处理CLI 定义阶段 每一条命令行都必须定义一组参数,它们被 ...
- Apache Commons CLI 开发命令行工具示例
概念说明Apache Commons CLI 简介 虽然各种人机交互技术飞速发展,但最传统的命令行模式依然被广泛应用于各个领域:从编译代码到系统管理,命令行因其简洁高效而备受宠爱.各种工具和系统都 提 ...
- The type org.apache.commons.cli.Options cannot be resolved. It is indirectly referenced from required .class files
在搭建好Hadoop Eclipse开发环境后,编写map-reduce,遇到如下的问题: 从字面上可以看出,工程缺少org.apache.commons.cli.Options,这个包被间接的被其他 ...
- 使用 Apache Commons CLI 开发命令行工具示例
Apache Commons CLI 简介 Apache Commons CLI 是 Apache 下面的一个解析命令行输入的工具包,该工具包还提供了自动生成输出帮助文档的功能. Apache Com ...
- 使用 Apache Commons CLI 解析命令行参数示例
很好的输入参数解析方法 ,转载记录下 转载在: https://www.cnblogs.com/onmyway20xx/p/7346709.html Apache Commons CLI 简介 Apa ...
- JAVA 命令行参数解析,org.apache.commons.cli的使用
maven依赖引入 <dependency> <groupId>commons-cli</groupId> <artifactId>commons-cl ...
- 使用commons.cli实现MyCP
目录 Commons.cli库 MyCP 测试代码 总结 Commons.cli库 考虑到这次的任务是实现自己的命令行命令cp,我认为简单地使用args[]无法很好的完成需求.经过网上的一番搜索,我找 ...
随机推荐
- Vmware虚拟硬盘合并多个分割文件
有时,当我们创建虚拟机vmware里面的应用程序,我们可能会选择创建分割的虚拟磁盘中的多个文件2 GB的文件,这是为了提高复制过程,主要用于存储虚拟机文件系统不支持创建更大的文件. 如果我们需要将它转 ...
- C++类成员函数
c++的两大特色是多态和模板.其中多态是通过继承和虚函数来实现的,其中虚函数是通过每个对象里面的虚表来实现的.如果这个对象的类有虚函数,那么这个类就有一张虚表,存的是每个虚函数的入口地址,而这个类的每 ...
- Unity3d中默认函数调用顺序(MonoBehaviour)
首先要明确的是MonoBehaviour是每个脚本的基类.每个Javascript脚本自动继承MonoBehaviour.使用C#或Boo时,需要显式继承MonoBehaviour. ...
- 玩转Bootstrap(JS插件篇)-第1章 模态弹出框 :1-3 模态弹出框
模态弹出框(Modals) 这一小节我们先来讲解一个“模态弹出框”,插件的源文件:modal.js. 右侧代码编辑器(30行)就是单独引入 bootstrap 中发布出的“modal.js”文件. 样 ...
- Android开发(十)——像素单位dp、px、pt、sp的比较
dp(dip): device independent pixels(设备独立像素). 不同设备有不同的显示效果,这个和设备硬件有关,一般我们为了支持WVGA.HVGA和QVGA 推荐使用这个,不依赖 ...
- Commons.net FTPClient 上传文件
使用 Commons.net FTPClient 上传 文件打不开. 原因,FTPClient 默认使用 ASCII 传输文件,FTP.ASCII_FILE_TYPE; 需要在登录代码后重新指定传输方 ...
- Website Develop: Handler “PageHandlerFactory-Integrated” has a bad module “ManagedPipelineHandler” in its module list
1. install all features in IIS 2. Try the following steps to register it. run %windir%\Microsoft.NET ...
- ios 6.1中 Release问题
程序中有如下代码: UIAlertView *alert = [[UIAlertView alloc] initWithTitle:@"Something was done." m ...
- java基础篇---Servlet监听器
在写此篇前,看了一下园友写的,感觉其基础知识归纳的十分全面,我在此就不累赘的写了,链接地址(http://www.cnblogs.com/sherryueda/p/4273169.html), 我就写 ...
- [转]JSTL 与 JSP 或者 Java 相互传递变量的代码
原文地址:http://blog.csdn.net/joyous/article/details/6689861 两种方式 <c:set var="s1" value=&qu ...