1、简述
picocli 是一个强大、易用且功能丰富的 java 库,用于开发命令行工具。它支持多级子命令、类型安全的参数解析和自动生成帮助信息,同时具有较低的学习曲线,是现代 cli 应用开发的理想选择。
2、为什么选择 picocli
简单易用:通过注解定义参数,减少手动解析逻辑。
强大功能:支持多种参数类型、子命令和多线程执行。
自动化:内置帮助信息和自动补全功能。
活跃社区:有详细的文档和大量实践案例。
picocli 的核心功能:
- 命令行参数解析:支持选项、位置参数、标志。
- 多级子命令:轻松实现复杂的命令行结构。
- 自动生成帮助信息:无需手动编写帮助文档。
- 多线程支持:通过 @commandline.command 中的 executionstrategy 轻松实现并发任务。
3、实践样例
以下是一个实践案例,展示如何使用 picocli 开发 cli 工具,构建一个简单的文件操作命令行工具:
3.1 添加依赖
在 maven 项目中添加 picocli 的依赖:
<dependency> <groupid>info.picocli</groupid> <artifactid>picocli</artifactid> <version>4.7.4</version> </dependency>
3.2 构建一个基本命令
下面创建一个简单的命令,支持对文件进行读取和统计操作。
import picocli.commandline; import picocli.commandline.command; import picocli.commandline.option; import java.io.ioexception; import java.nio.file.files; import java.nio.file.paths; import java.util.concurrent.callable; @command(name = "filetool", version = "filetool 1.0", description = "一个用于文件操作的命令行工具", mixinstandardhelpoptions = true) public class filetool implements callable<integer> { @option(names = {"-p", "--path"}, description = "文件路径", required = true) private string filepath; @option(names = {"-c", "--count-lines"}, description = "统计文件行数") private boolean countlines; @option(names = {"-r", "--read-content"}, description = "读取并输出文件内容") private boolean readcontent; @override public integer call() throws exception { if (countlines) { long linecount = files.lines(paths.get(filepath)).count(); system.out.println("文件行数: " + linecount); } if (readcontent) { string content = new string(files.readallbytes(paths.get(filepath))); system.out.println("文件内容:\n" + content); } return 0; } public static void main(string[] args) { int exitcode = new commandline(new filetool()).execute(args); system.exit(exitcode); } }
3.3 使用说明
编译并运行程序后,可以通过以下方式使用该工具:
查看帮助信息:
java -jar filetool.jar --help
输出示例:
用法: filetool [-hv] [-c] [-r] -p=<filepath>
一个用于文件操作的命令行工具
-c, --count-lines 统计文件行数
-h, --help 显示帮助信息
-p, --path=<filepath> 文件路径
-r, --read-content 读取并输出文件内容
-v, --version 打印版本信息
统计文件行数:
java -jar filetool.jar -p sample.txt -c
输出示例:
文件行数: 10
读取文件内容:
java -jar filetool.jar -p sample.txt -r
输出示例:
文件内容:
hello world!
this is a test file.
4、高级功能示例
picocli 支持子命令,可以用于实现复杂的 cli 工具。以下是一个示例,构建一个多功能工具,包含子命令 read 和 count:
@command(name = "filetool", description = "文件工具", mixinstandardhelpoptions = true, subcommands = { filereadcommand.class, filecountcommand.class }) public class filetool { public static void main(string[] args) { int exitcode = new commandline(new filetool()).execute(args); system.exit(exitcode); } } @command(name = "read", description = "读取文件内容") class filereadcommand implements callable<integer> { @option(names = {"-p", "--path"}, description = "文件路径", required = true) private string filepath; @override public integer call() throws exception { string content = new string(files.readallbytes(paths.get(filepath))); system.out.println("文件内容:\n" + content); return 0; } } @command(name = "count", description = "统计文件行数") class filecountcommand implements callable<integer> { @option(names = {"-p", "--path"}, description = "文件路径", required = true) private string filepath; @override public integer call() throws exception { long linecount = files.lines(paths.get(filepath)).count(); system.out.println("文件行数: " + linecount); return 0; } }
运行示例:
查看帮助信息:
java -jar filetool.jar --help
使用子命令 read:
java -jar filetool.jar read -p sample.txt
使用子命令 count:
java -jar filetool.jar count -p sample.txt
5、总结
picocli 是一个现代化的 java 命令行工具开发库,通过简单的注解和直观的 api 提供强大的功能。无论是实现单一命令,还是构建多级子命令的复杂工具,picocli 都能快速满足需求。
推荐的使用场景:
开发运维工具:如文件管理工具、数据处理工具。
数据分析脚本:支持多线程处理。
多子命令的框架型 cli 工具。
到此这篇关于java利用picocli开发一个简化命令行工具的文章就介绍到这了,更多相关java picocli简化命令行内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!
发表评论