Apache的commons-cli包是专门用于解析命令行参数格式的包。
依赖:
<dependency> <groupId>commons-cli</groupId> <artifactId>commons-cli</artifactId> <version>1.3.1</version> </dependency>
使用此包需要:
1.先定义有哪些参数需要解析、哪些参数有额外的选项、每个参数的描述等等,对应Options类
比如说一个命令行参数是 -hfbv,我们定义的Options的目的是,说明哪些参数是真正需要解析的参数:如我们定义了Option:h、f、b,那么在解析的时候解析器就可以知道怎么去用定义的Option匹配命令行从而获取每个参数。而且可以定义哪些参数需要选项,如tar -f ,f参数就需要文件名选项,通过定义解析器才可以把f后面的内容解析为f指定的文件名。
2.根据定义的需要解析的参数对命令行参数进行解析,对应CommandLineParser类
根据定义的Options对象去解析传入的String[] argus参数,从而匹配出每个参数,然后我们就可以单独获取每个参数。
3.解析完成返回CommandLine对象,由这个对象可获取此次命令行参数的信息。
可以从这个对象中知道哪些参数输入了,哪些参数没有输入,哪些参数的额外选项的内容等等。然后我们就能自己写代码根据不同参数执行不同逻辑了。
示例代码:
import java.io.File; import java.io.IOException; import java.util.ArrayList; import java.util.Arrays; import java.util.HashSet; import org.apache.commons.cli.CommandLine; import org.apache.commons.cli.CommandLineParser; import org.apache.commons.cli.DefaultParser; import org.apache.commons.cli.HelpFormatter; import org.apache.commons.cli.Option; import org.apache.commons.cli.Options; import org.apache.commons.cli.ParseException; import com.lwt.util.DirUtil; public class CommandLineUtil { private String[] args; private Options opts = new Options(); private File keyFile; private boolean encrypt; private boolean create; private boolean enName; private File[] files; private File[] dirs; public File getKeyFile() { return keyFile; } public boolean isEncrypt() { return encrypt; } public boolean isEnName() { return enName; } public boolean isCreate() { return create; } public File[] getFiles() { return files; } public File[] getDirs() { return dirs; } public CommandLineUtil(String[] args) { this.args = args; definedOptions(); parseOptions(); duplicate_removal(); } // 定义命令行参数 private void definedOptions(){ Option opt_h = new Option("h", "Show this page."); Option opt_e = new Option("e", "encrypt", false, "Encrypt file."); Option opt_d = new Option("d", "decrypt", false, "Decrypt file."); Option opt_c = new Option("c", "create", false, "Create new key file."); Option opt_n = new Option("n", "name", false, "Encrypt file name."); Option opt_k = Option.builder("k").hasArg().argName("keyFile") .desc("Specify the key file").build(); Option opt_f = Option.builder("f").hasArgs().argName("file1,file2...") .valueSeparator(',') .desc("A files list with ',' separate to handle").build(); Option opt_r = Option .builder("r") .hasArgs() .argName("dir1,dir1...") .valueSeparator(',') .desc("A directories list with ',' separate to handle its child files") .build(); Option opt_R = Option .builder("R") .hasArgs() .argName("dir1,dir1...") .valueSeparator(',') .desc("A directories list with ',' separate to recurse handle child files") .build(); opts.addOption(opt_n); opts.addOption(opt_c); opts.addOption(opt_k); opts.addOption(opt_h); opts.addOption(opt_e); opts.addOption(opt_d); opts.addOption(opt_f); opts.addOption(opt_r); opts.addOption(opt_R); } // 解析处理命令行参数 private void parseOptions(){ CommandLineParser parser = new DefaultParser(); CommandLine line = null; // 解析命令行参数 try { line = parser.parse(opts, args); } catch (ParseException e) { System.err.println(e.getMessage()); System.exit(1); } // 若指定h则显示帮助 if (args == null || args.length == 0 || line.hasOption("h")) { HelpFormatter help = new HelpFormatter(); help.printHelp("encrypt", opts); } // 选择加密或解密操作,默认是加密文件 if (line.hasOption("d")) { if (line.hasOption("e")) { System.err .println("The -e and -d option can't specify at the same time."); System.exit(1); } encrypt = false; } else { encrypt = true; if(line.hasOption("n")){ enName = true; } } if (line.hasOption("k")) { String k = line.getOptionValue("k"); File file = new File(k); if (line.hasOption("c")) { keyFile = file; create = true; }else { if(file.isFile()){ keyFile = file; } else{ System.err.println(file + " is not a available key file"); System.exit(1); } } } ArrayList<File> files = new ArrayList<File>(); ArrayList<File> dirs = new ArrayList<File>(); if (line.hasOption("f")) { String[] fs = line.getOptionValues("f"); for(String f : fs){ File file = new File(f); if(file.isFile()){ files.add(file); }else{ System.err.println(file + " is not a file"); System.exit(1); } } } if (line.hasOption("r")) { String[] rs = line.getOptionValues("r"); for(String r : rs){ File dir = new File(r); if(dir.isDirectory()){ dirs.add(dir); DirUtil dirUtil = new DirUtil(dir); files.addAll(Arrays.asList(dirUtil.getFiles())); dirs.addAll(Arrays.asList(dirUtil.getDirs())); }else{ System.err.println(dir + " is not a directory"); System.exit(1); } } } if (line.hasOption("R")) { String[] Rs = line.getOptionValues("R"); for(String R : Rs){ File dir = new File(R); if(dir.isDirectory()){ dirs.add(dir); DirUtil dirUtil = new DirUtil(dir); files.addAll(Arrays.asList(dirUtil.getAllFiles())); dirs.addAll(Arrays.asList(dirUtil.getAllDirs())); }else{ System.err.println(dir + " is not a directory"); System.exit(1); } } } this.files = files.toArray(new File[0]); this.dirs = dirs.toArray(new File[0]); } public void duplicate_removal (){ HashSet<File> fileSet = new HashSet<File>(); for(File file : files){ try { fileSet.add(file.getCanonicalFile()); } catch (IOException e) { System.err.println(e.getMessage()); System.exit(1); } } files = fileSet.toArray(new File[0]); fileSet = new HashSet<File>(); for(File dir : dirs){ try { fileSet.add(dir.getCanonicalFile()); } catch (IOException e) { System.err.println(e.getMessage()); System.exit(1); } } dirs = fileSet.toArray(new File[0]); } }
总结
以上所述是小编给大家介绍的使用Apache commons-cli包进行命令行参数解析的示例代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对小牛知识库网站的支持!
主要内容:flag 包概述,flag 参数类型,flag 包基本使用在编写命令行程序(工具、server)时,我们有时需要对命令参数进行解析,各种编程语言一般都会提供解析命令行参数的方法或库,以方便程序员使用。在Go语言中的 flag 包中,提供了命令行参数解析的功能。 下面我们就来看一下 flag 包可以做什么,它具有什么样的能力。 这里介绍几个概念: 命令行参数(或参数):是指运行程序时提供的参数; 已定义命令行参数:是指程序中通过 flag.Type 这种形
在写命令行程序(工具、server)时,对命令参数进行解析是常见的需求。各种语言一般都会提供解析命令行参数的方法或库,以方便程序员使用。如果命令行参数纯粹自己写代码解析,对于比较复杂的,还是挺费劲的。在 go 标准库中提供了一个包:flag,方便进行命令行解析。 注:区分几个概念 命令行参数(或参数):是指运行程序提供的参数 已定义命令行参数:是指程序中通过flag.Xxx等这种形式定义了的参数
与TCP命令解析同理,直接上代码 解析器 namespace AppSock; use CoreComponentSocketAbstractInterfaceAbstractClient; use CoreComponentSocketAbstractInterfaceAbstractCommandParser; use CoreComponentSocketCommonCommand; cla
EasySwoole支持用户进行自定义格式的命令解析与路由。以下我们将以最基础的例子作为讲解。 建立自定义命令解析类 namespace AppSock; use CoreComponentSocketAbstractInterfaceAbstractClient; use CoreComponentSocketAbstractInterfaceAbstractCommandParser; use
问题内容: 如果我想解析该怎么办: 我想要的结果是: 我更喜欢使用Apache Commons CLI ,但是文档对我上面提到的情况有些不清楚。具体来说,文档没有告诉您如何处理我在下面指定的第3种类型的选项: 我希望Apache Commons CLI可以正常工作,但是如果这些args没有选项前缀,仍然可以将常规args传递给程序。也许可以,但是文档没有这么说,因此在我阅读它时… 问题答案: 您可
本文向大家介绍python命令行参数用法实例分析,包括了python命令行参数用法实例分析的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了python命令行参数用法。分享给大家供大家参考,具体如下: 在命令行下执行某些命令的时候,通常会在一个命令后面带上一些参数,这些参数会传递到程序里,进行处理,然后返回结果,在linux 下很多命令其实也是用python来实现的。那么如果做到在命令行输入