【Qt 读取、修改、存储.ini文件】及完整示例

在 Qt 中,QSettings 类被广泛用于读取、修改和存储 .ini 文件。这个类提供了一个简洁的 API 来处理配置数据,它使用 .ini 文件格式或系统特定的存储机制(例如 Windows 注册表)来存储应用程序的设置。

读取 .ini 文件

要读取 .ini 文件,您可以使用 QSettings 类,并指定文件路径和格式。以下是一个读取操作的示例:

cpp 复制代码
QSettings settings("config.ini", QSettings::IniFormat);
QString value = settings.value("section/key", "default_value").toString();

在这个例子中,settings 对象被初始化为使用 config.ini 文件,并且以 IniFormat 格式读取数据。value 函数用于获取特定节(section)和键(key)的值,如果该键不存在,则返回默认值 "default_value"

修改 .ini 文件

修改 .ini 文件同样使用 QSettings 类,您可以使用 setValue 方法来设置新的值:

cpp 复制代码
QSettings settings("config.ini", QSettings::IniFormat);
settings.setValue("section/key", "new_value");

这段代码将 config.ini 文件中 section 节下的 key 的值修改为 "new_value"

存储 .ini 文件

QSettings 类在修改设置时会自动存储更改。但是,如果您想确保所有更改立即写入磁盘,可以调用 sync 方法:

cpp 复制代码
settings.sync();

这将确保所有未写的更改被写入到 .ini 文件中。

-----

下面是一个使用 Qt 和 QSettings 类来读取、修改和存储 .ini 文件的完整示例。这个示例中,.ini 文件将包含两个模块(节),分别是 UserSettings

.ini 文件中的内容应该是这样的:

ini 复制代码
[User]
Name=New User
Age=30

[Settings]
StartMinimized=true

示例代码

cpp 复制代码
#include <QCoreApplication>
#include <QSettings>
#include <QDebug>

int main(int argc, char *argv[])
{
    QCoreApplication a(argc, argv);

    // 指定.ini文件名称和格式
    QSettings settings("config.ini", QSettings::IniFormat);

    // 读取操作
    QString userName = settings.value("User/Name", "Default User").toString();
    int userAge = settings.value("User/Age", 25).toInt();
    qDebug() << "User Name:" << userName;
    qDebug() << "User Age:" << userAge;

    bool startMinimized = settings.value("Settings/StartMinimized", false).toBool();
    qDebug() << "Start Minimized:" << startMinimized;

    // 修改操作
    userName = "New User";
    userAge = 30;
    startMinimized = true;

    settings.beginGroup("User");
    settings.setValue("Name", userName);
    settings.setValue("Age", userAge);
    settings.endGroup();

    settings.beginGroup("Settings");
    settings.setValue("StartMinimized", startMinimized);
    settings.endGroup();

    // 存储操作(通常不需要显式调用,因为QSettings会自动保存)
    settings.sync();

    // 再次读取以验证修改
    QString updatedUserName = settings.value("User/Name").toString();
    int updatedUserAge = settings.value("User/Age").toInt();
    qDebug() << "Updated User Name:" << updatedUserName;
    qDebug() << "Updated User Age:" << updatedUserAge;

    bool updatedStartMinimized = settings.value("Settings/StartMinimized", false).toBool();
    qDebug() << "Updated Start Minimized:" << updatedStartMinimized;

    return a.exec();
}

说明

  1. 初始化 QSettings

    • 创建一个 QSettings 对象,指定 .ini 文件的名称和路径(如果没有提供路径,文件将保存在当前工作目录)。
  2. 读取操作

    • 使用 value() 方法读取特定节下的键值。如果键不存在,返回提供的默认值。
  3. 修改操作

    • 使用 setValue() 方法修改或添加新的键值对。
    • 使用 beginGroup()endGroup() 来指定节(模块),这样可以组织相关的设置。
  4. 存储操作

    • 虽然 QSettings 会自动保存更改,但调用 sync() 方法可以确保所有更改立即写入文件。
  5. 验证修改

    • 重新读取修改后的值,以验证更改是否成功保存。
相关推荐
伏飞而行13 分钟前
六、元素应用CSS的习题
1024程序员节
末时清15 分钟前
QT交互界面:实现按钮运行脚本程序
开发语言·qt·交互
idealzouhu26 分钟前
Spring Boot 实现文件上传下载功能
java·spring boot·1024程序员节
sudo_Ene39 分钟前
Isaac Sim Docker 部署并使用过程记录
笔记·学习·docker·1024程序员节·isaacsim
天使的同类2 小时前
uniapp使用easyinput文本框显示输入的字数和限制的字数
1024程序员节
Elastic 中国社区官方博客2 小时前
GraphQL 与 Elasticsearch 相遇:使用 Hasura DDN 构建可扩展、支持 AI 的应用程序
大数据·后端·elasticsearch·搜索引擎·全文检索·graphql·1024程序员节
·云扬·2 小时前
WeakHashMap详解
java·开发语言·学习·1024程序员节
Dennis_nafla3 小时前
《MYSQL实战45讲》表数据删一半,为什么表文件大小不变?
mysql·1024程序员节
在人间负债^3 小时前
合约门合同全生命周期管理系统:企业智能合同管理的新时代
1024程序员节
CloudHu19893 小时前
2024年1024程序人生总结
1024程序员节