Java – how to specify multiple options using Apache commons cli?
•
Java
What I want:
java programName -jobs1 -C 10 -W 20 java programName -job2 java programName -job3
Content:
Option o1 = new Option("job2","some desc"); Option o2 = new Option("job3","(some desc") Option o3 = OptionBuilder.hasArgs(2).withArgName( "W" ).withArgName("C").withDescription( "Some desc" ).create("job1") Option o4 = new Option("help"); Options os = new Options().addOption(o1).addOption(o2).addOption(o3).addOption(o4). Helpformatter formatter = new Helpformatter(); formatter.printHelp( "ProgramName",options );
... the location of the output is:
Usage ProgramName -job1 <c> Some Desc -job2 Some desc -job3 Some desc -help Print this message
I hope - job1 it should print - job1 - C < > - W < >
Did I miss anything? It does not apply to multiple parameters By the way, I used commons cli 1.2
Solution
You cannot have context sensitive parameters You can have the following parameters: job1, job2, job3, C & W, but you can't say (through the Library) that C & W is only valid for job1
If job1 / 2 / 3 is mutually exclusive, create an OptionGroup Then, in the code, make sure that C & W is only used for job1
import org.apache.commons.cli.CommandLine; import org.apache.commons.cli.CommandLineParser; import org.apache.commons.cli.GnuParser; import org.apache.commons.cli.Option; import org.apache.commons.cli.OptionBuilder; import org.apache.commons.cli.OptionGroup; import org.apache.commons.cli.Options; import org.apache.commons.cli.Helpformatter; public class StackOverflowExample { public static final String JOB1 = "job1"; public static final Option job1 = OptionBuilder.hasArg(false) .isrequired(false) .withDescription("description of job1") .create(JOB1); public static final String JOB2 = "job2"; public static final Option job2 = OptionBuilder.hasArg(false) .isrequired(false) .withDescription("description of job2") .create(JOB2); public static final String JOB3 = "job3"; public static final Option job3 = OptionBuilder.hasArg(false) .isrequired(false) .withDescription("description of job3") .create(JOB3); public static final String MY_C = "C"; public static final Option my_c = OptionBuilder.hasArg(true) .withArgName("count") .isrequired(false) .withDescription("description of C") .create(MY_C); public static final String MY_W = "W"; public static final Option my_w = OptionBuilder.hasArg(true) .withArgName("width") .isrequired(false) .withDescription("description of W") .create(MY_W); public static void main(String[] args) { Options options = new Options(); OptionGroup optgrp = new OptionGroup(); optgrp.addOption(job1); optgrp.addOption(job2); optgrp.addOption(job3); options.addOptionGroup(optgrp); options.addOption(my_c); options.addOption(my_w); try { CommandLineParser parser = new GnuParser(); CommandLine cmdline = parser.parse(options,args); if (((cmdline.hasOption(MY_C)) || (cmdline.hasOption(MY_W))) && (! cmdline.hasOption(JOB1))) { Helpformatter help = new Helpformatter(); help.printHelp("cmdname",options); System.exit(-1); } System.out.println("OK"); } catch (Exception ex) { ex.printStackTrace(); System.exit(-1); } } }
The following outputs are generated:
<~/sand@R_139_2419@/CoreUtils/scratch> $javac -d . -cp ~/sand@R_139_2419@/CoreUtils/lib/commons-cli-1.2.jar:. StackOverflowExample.java <~/sand@R_139_2419@/CoreUtils/scratch> $java -cp ~/sand@R_139_2419@/CoreUtils/lib/commons-cli-1.2.jar:. StackOverflowExample -C foo -job1 OK <~/sand@R_139_2419@/CoreUtils/scratch> $java -cp ~/sand@R_139_2419@/CoreUtils/lib/commons-cli-1.2.jar:. StackOverflowExample -C foo -job2 usage: cmdname -C <count> description of C -job1 description of job1 -job2 description of job2 -job3 description of job3 -W <width> description of W
The content of this article comes from the network collection of netizens. It is used as a learning reference. The copyright belongs to the original author.
THE END
二维码