【开源-常用C/C++命令行解析库对比】

ops/2025/3/4 13:20:18/

以下是几种常用的C/C++命令行解析库的对比表格,以及它们的GitHub开源库地址:

库名称语言特点是否支持子命令是否支持配置文件是否支持自动生成帮助信息GitHub地址
ClaraC++11及以上单一头文件,轻量级,非异常错误处理,自动类型转换Clara GitHub
cxxoptsC++11及以上单一头文件,轻量级,支持多种数据类型,自动帮助信息cxxopts GitHub
CLI11C++11及以上功能强大,支持子命令、配置文件,自动生成帮助信息CLI11 GitHub
argparseC++17现代C++17头文件库,支持多种参数类型,自动帮助信息argparse GitHub
CmdlineC++轻量级,支持布尔标志和参数绑定,自动生成帮助信息Cmdline GitHub
cargsC/C++轻量级,支持多种参数类型,自动生成帮助信息cargs GitHub

选择建议:

  1. 如果你需要轻量级且易于集成的库,可以选择 Claracxxopts,它们都是单一头文件库,易于集成到项目中。
  2. 如果你需要功能强大且支持复杂命令行接口CLI11 是一个不错的选择,它支持子命令、配置文件和自动生成帮助信息。
  3. 如果你使用的是C语言或需要兼容C语言的库,可以考虑 cargs
  4. 如果你需要现代C++17特性支持argparse 是一个简洁且功能丰富的选择。

以下是几种常用C/C++命令行解析库的简单使用示例

1. Clara

GitHub地址:Clara GitHub
示例代码:
#include <boost/program_options.hpp>
#include <iostream>namespace po = boost::program_options;int main(int argc, char* argv[]) {po::options_description desc("Allowed options");desc.add_options()("help,h", "produce help message")("compression,c", po::bool_switch(), "enable compression");po::variables_map vm;po::store(po::parse_command_line(argc, argv, desc), vm);po::notify(vm);if (vm.count("help")) {std::cout << desc << "\n";return 1;}bool compression = vm["compression"].as<bool>();std::cout << "Compression is " << (compression ? "on" : "off") << ".\n";return 0;
}
输出示例:
$ ./example --help
Allowed options:--help,h         produce help message--compression,c  enable compression

2. cxxopts

GitHub地址:cxxopts GitHub
示例代码:
#include <cxxopts.hpp>
#include <iostream>int main(int argc, char* argv[]) {cxxopts::Options options("This is a test program.", "This goes after the options.");options.add_options()("h,help", "Print usage")("n,name", "Your name", cxxopts::value<std::string>())("a,age", "Your age", cxxopts::value<int>());auto result = options.parse(argc, argv);if (result.count("help")) {std::cout << options.help() << std::endl;return 0;}std::string name = result["name"].as<std::string>();int age = result["age"].as<int>();std::cout << "Hello, " << name << "! You are " << age << " years old." << std::endl;return 0;
}
输出示例:
$ ./example --name John --age 30
Hello, John! You are 30 years old.

3. CLI11

GitHub地址:CLI11 GitHub
示例代码:
#include <CLI/CLI.hpp>
#include <iostream>int main(int argc, char* argv[]) {CLI::App app{"This is a test application."};std::string name;int age;app.add_option("-n,--name", name, "Your name")->required();app.add_option("-a,--age", age, "Your age")->required();CLI11_PARSE(app, argc, argv);std::cout << "Hello, " << name << "! You are " << age << " years old." << std::endl;return 0;
}
输出示例:
$ ./example --name Alice --age 25
Hello, Alice! You are 25 years old.

4. argparse

GitHub地址:argparse GitHub
示例代码:
#include <argparse/argparse.hpp>
#include <iostream>int main(int argc, char* argv[]) {argparse::ArgumentParser program("This is a test program.");program.add_argument("-n", "--name").help("Your name").required();program.add_argument("-a", "--age").help("Your age").required();try {program.parse_args(argc, argv);} catch (const std::runtime_error& err) {std::cerr << err.what() << std::endl;std::cerr << program;return 1;}std::string name = program.get<std::string>("--name");int age = program.get<int>("--age");std::cout << "Hello, " << name << "! You are " << age << " years old." << std::endl;return 0;
}
输出示例:
$ ./example --name Bob --age 40
Hello, Bob! You are 40 years old.

5. Cmdline

GitHub地址:Cmdline GitHub
示例代码:
#include <cmdline.h>
#include <iostream>int main(int argc, char* argv[]) {cmdline::parser p;p.add<std::string>("name", 'n', "Your name", true);p.add<int>("age", 'a', "Your age", true);p.parse_check(argc, argv);std::string name = p.get<std::string>("name");int age = p.get<int>("age");std::cout << "Hello, " << name << "! You are " << age << " years old." << std::endl;return 0;
}
输出示例:
$ ./example -n Charlie -a 35
Hello, Charlie! You are 35 years old.

6. cargs

GitHub地址:cargs GitHub
示例代码:
#include <cargs.h>
#include <stdio.h>int main(int argc, char* argv[]) {cargs_parser_t parser = cargs_parser_create("This is a test program.");cargs_add_option(parser, "name", 'n', "Your name", CARGS_STRING);cargs_add_option(parser, "age", 'a', "Your age", CARGS_INT);if (!cargs_parse(parser, argc, argv)) {cargs_print_help(parser);return 1;}char* name = cargs_get_string(parser, "name");int age = cargs_get_int(parser, "age");printf("Hello, %s! You are %d years old.\n", name, age);cargs_parser_destroy(parser);return 0;
}
输出示例:
$ ./example -n David -a 28
Hello, David! You are 28 years old.

总结

以上是六种常用命令行解析库的简单示例。每种库都有其特点和适用场景,你可以根据项目需求选择合适的工具。希望这些示例对你有所帮助!


http://www.ppmy.cn/ops/163050.html

相关文章

HTML元素,标签到底指的哪块部分?单双标签何时使用?

1. 标签&#xff08;Tag&#xff09; vs 元素&#xff08;Element&#xff09; 标签&#xff08;Tag&#xff09; 标签是 HTML 中用于定义元素的符号&#xff0c;用尖括号 < > 包裹。例如 <img> 是标签。元素&#xff08;Element&#xff09; 元素是由 标签 内容…

芯麦GC1277:电脑散热风扇驱动芯片的优质之选 并可替代传统的0CH477/灿瑞芯片。

在电脑散热风扇、小型电机驱动等场景中&#xff0c;驱动芯片的选型直接影响系统效率、噪音控制及长期可靠性。灿瑞的0CH477曾是市场主流方案&#xff0c;但随着国产芯片技术的成熟&#xff0c;芯麦半导体推出的GC1277凭借更优的驱动性能、智能化保护机制及成本优势&#xff0c;…

【uniapp原生】实时记录接口请求延迟,并生成写入文件到安卓设备

在开发实时数据监控应用时&#xff0c;记录接口请求的延迟对于性能分析和用户体验优化至关重要。本文将基于 UniApp 框架&#xff0c;介绍如何实现一个实时记录接口请求延迟的功能&#xff0c;并深入解析相关代码的实现细节。 前期准备&必要的理解 1. 功能概述 该功能的…

git的恢复命令

右键查看 找到版本的 提交ID git reset --soft c097b534188163194fa0e00a20d9e0f07ad82549

word转换为pdf后图片失真解决办法、高质量PDF转换方法

1、安装Adobe Acrobat Pro DC 自行安装 2、配置Acrobat PDFMaker &#xff08;1&#xff09;点击word选项卡上的Acrobat插件&#xff0c;&#xff08;2&#xff09;点击“首选项”按钮&#xff0c;&#xff08;3&#xff09;点击“高级配置”按钮&#xff08;4&#xff09;点…

蓝桥杯复盘记录004(2023)

涉及知识点 1.深搜 2.单调队列滑动窗口 3.位运算 4.并查集 题目 1.lanqiao3505 思路&#xff1a; dfs(index, weight, cnt) index表示瓜的索引&#xff0c; weight等于买瓜的重量&#xff0c; cnt表示买了多少瓜。 递归终止条件&#xff1a;1.如果瓜买完了&#xff0c;归…

如何免费使用稳定的deepseek

0、背景&#xff1a; 在AI辅助工作中&#xff0c;除了使用cursor做编程外&#xff0c;使用deepseek R1进行问题分析、数据分析、代码分析效果非常好。现在我经常会去拿行业信息、遇到的问题等去咨询R1&#xff0c;也给了自己不少启示。但是由于官网稳定性很差&#xff0c;很多…

iPhone 镜像 连接错误

重置连接 defaults delete com.apple.ScreenContinuity打开 iPhone 镜像 参考 mac镜像iPhone无法连接报错个人经历的 iPhone 镜像 bug 与部分解决办法