推荐使用SimpleIni或inipp库解析C++ INI文件,若无法引入第三方库则可手动解析;SimpleIni支持读写且跨平台,inipp为纯头文件仅支持读取,手动解析通过逐行处理实现配置读取。

在C++中解析INI配置文件,虽然标准库没有直接支持,但可以通过多种方式实现。常用的方法包括使用第三方库或手动解析文本文件。以下是几种实用的C++ INI文件解析方法。
使用SimpleIni库解析
SimpleIni是一个轻量级、跨平台的C++库,支持读写INI格式文件,使用简单且无需依赖其他库。步骤:
- 从官网或GitHub下载SimpleIni源码(通常只有一个头文件:SimpleIni.h)
- 将头文件加入项目
- 包含头文件并使用其API读取配置
示例代码:
// 示例:使用SimpleIni读取配置#include "SimpleIni.h"CSimpleIniA ini; ini.SetUnicode(); ini.LoadFile("config.ini");
const char* value = ini.GetValue("section", "key", "default_value"); int num = atoi(ini.GetValue("section", "count", "0"));
保存修改也很方便:
立即学习“C++免费学习笔记(深入)”;
ini.SetValue("section", "key", "new_value");
ini.SaveFile("config.ini");
使用inipp库(Header-only)
inipp是一个纯头文件的C++ INI解析器,仅支持读取,不依赖外部库,适合嵌入式或轻量项目。使用方法:
- 下载 inipp.h 头文件
- 包含后定义一个std::map来存储节和键值对
示例代码:
#include "inipp.h" #include#include
支持自动类型转换(int、double等),简洁高效。
手动解析文本文件
如果项目不允许引入第三方库,可以手动读取和解析INI文件。基本思路:
- 逐行读取文件
- 判断是否为节名([section])
- 解析 key=value 格式
- 跳过注释(; 或 # 开头)
示例片段:
std::ifstream f("config.ini");
std::string line;
std::string section;
std::map> config;
while (getline(f, line)) {
// 去除空白字符
line.erase(0, line.find_first_not_of(" \t"));
line.erase(line.find_last_not_of(" \t") + 1);
if (line.empty() || line[0] == ';' || line[0] == '#') continue;
if (line[0] == '[' && line.back() == ']') {
section = line.substr(1, line.size() - 2);
} else {
size_t eq = line.find('=');
if (eq != std::string::npos) {
std::string key = line.substr(0, eq);
std::string value = line.substr(eq + 1);
config[section][key] = value;
}
}}
之后可通过 config["section"]["key"] 获取值。
推荐方案选择
根据项目需求选择合适方式:
- 需要读写且功能完整 → 使用 SimpleIni
- 只读配置且追求轻量 → 使用 inipp
- 不能引入外部代码 → 手动解析
基本上就这些。选择合适的方法能快速集成INI配置支持,提升项目可配置性。










