org.apache.common.cli 命令行参数解析

本文介绍如何使用commons-cli库在Java应用中解析命令行参数。包括Maven依赖配置、定义Option对象、解析命令行参数及获取参数值的方法,并提供帮助信息的打印方式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Java命令行解析参数
1. Maven引入依赖
<dependency>
    <groupId>commons-cli</groupId>
    <artifactId>commons-cli</artifactId>
    <version>1.4</version>
</dependency>


2. 定义各种option

Options options = new Options();

1) 通过Option对象

Option opt = new Option("h", "help", false, "Print help");
opt.setRequired(false); //是否必须含有该参数
options.addOption(opt);


其中Option的参数:

第一个参数:参数的简单形式
第二个参数:参数的复杂形式
第三个参数:是否需要额外的输入

第四个参数:对参数的描述信息

2)直接使用Options的重载函数

options.addOption("h", "help", false, "Print help"); 

3)使用OptionBuilder得到Option对象  1.3废弃OptionBuilder

    使用Option.Builder得到Option对象

    

Option c = Option.builder("c")                                    //c就是opt
                 .required(false)                                       //是否必须含有该参数
                 .hasArg()                                               //带一个参数
                 .argName("filename")                             //参数的名字
                 .desc("return sum of characters")            //描述

                 .build();

  • public Option.Builder argName(String argName)            #我也不知道这个有啥用
  • public Option.Builder longOpt(String longOpt)               #参数的长名称
  • public Option.Builder hasArg()                                     #默认包含一个参数
  • public Option.Builder hasArg(boolean hasArg)                #是否包含参数
  • public Option.Builder hasArgs()                                    #代码中将参数长度设为-2,不知道啥意思
  • public Option.Builder desc(String description)                #描述
  • public Option.Builder required()                                    #默认必须包含该参数
  • public Option.Builder required(boolean required)            #是否必须包含该参数
  • public Option.Builder type(Class<?> type)
  • public Option build()                         当opt和longOpt都为null 会产生异常

Option.Builder只有私有的构造函数,所以只能通过Option类的成员函数

                        public static Option.Builder builder()

                        public static Option.Builder builder(String opt)

创建得到Option.Builder对象


3. 解析命令行


1)
CommandLineParser paraer = new BasicParser();          1.3Deprecated.
CommandLineParser parser = new PosixParser(); 1.3Deprecated
CommandLineParser parser = new GnuParser(); 1.3Deprecated
CommandLineParser parser = new DefaultParser(); ok


2) CommandLine cmd= paraer.parse(options, args);




4. 获取参数
1) 判断是否含有指定的参数
if(cmd.hasOption("help")){
}


2) 获得某个命令对应的参数
String arg = cmd.getOptionValue('c')



5. 打印帮助
HelpFormatter hf = new HelpFormatter();
hf.printHelp("Options", options);








[root@slave2 /]# flink run-application -t yarn-application -Dparallelism.default=6 \ # 全局默认并行度SLF4J: Class path contains multiple SLF4J bindings. SLF4J: Found binding in [jar:file:/opt/service/flink/lib/log4j-slf4j-impl-2.17.1.jar!/org/slf4j/impl/StaticLoggerBinder.class] SLF4J: Found binding in [jar:file:/opt/service/hadoop/share/hadoop/common/lib/slf4j-reload4j-1.7.36.jar!/org/slf4j/impl/StaticLoggerBinder.class] SLF4J: See http://www.slf4j.org/codes.html#multiple_bindings for an explanation. SLF4J: Actual binding is of type [org.apache.logging.slf4j.Log4jLoggerFactory] ------------------------------------------------------------ The program finished with the following exception: java.net.URISyntaxException: Illegal character in path at index 0: at java.net.URI$Parser.fail(URI.java:2848) at java.net.URI$Parser.checkChars(URI.java:3021) at java.net.URI$Parser.parseHierarchical(URI.java:3105) at java.net.URI$Parser.parse(URI.java:3063) at java.net.URI.<init>(URI.java:588) at org.apache.flink.client.program.PackagedProgramUtils.resolveURI(PackagedProgramUtils.java:243) at org.apache.flink.client.cli.CliFrontend.runApplication(CliFrontend.java:200) at org.apache.flink.client.cli.CliFrontend.parseAndRun(CliFrontend.java:1098) at org.apache.flink.client.cli.CliFrontend.lambda$mainInternal$9(CliFrontend.java:1189) at java.security.AccessController.doPrivileged(Native Method) at javax.security.auth.Subject.doAs(Subject.java:422) at org.apache.hadoop.security.UserGroupInformation.doAs(UserGroupInformation.java:1899) at org.apache.flink.runtime.security.contexts.HadoopSecurityContext.runSecured(HadoopSecurityContext.java:41) at org.apache.flink.client.cli.CliFrontend.mainInternal(CliFrontend.java:1189) at org.apache.flink.client.cli.CliFrontend.main(CliFrontend.java:1157) [root@slave2 /]#
最新发布
03-14
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值